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In this Issue 

In the early days, computer output came from a line printer on oversize 
V fanfold computer paper. Today there are alternatives, but if you took at any 
S\ large computer you'll probably still find a line printer attached, spitting out 
the same fanfold computer paper at a rate that causes concern about the 
adequacy of our tree farms. Of the several kinds of line printers available. 
those that offer the most flexibility and generally better and more consistent 
print quality are the dot matrix impact line printers. Characters are printed 
as dot patterns, each dot produced by striking the paper through an inked 
ribbon with a hammer or a pnntwire. These printers have been available 
with print speeds up to 600 132-character lines per minute. Starting on page 4, most of the articles 
in this issue deal with the design of a new family of dot matrix impact line printers that extends 
this performance to 900 lines per minute with greatly improved reliability and lower cost. The 
family consists of a low-cost 300-line-per-minute model and two heavy-duty models that print at 
600 and 900 lines per minute, respectively. The key element in the performance of these printers 
is a new printbar, shown in action on the cover and described in the article on page 6. This 
printbar has one hammer for each character position (each four positions in the low-cost model). 
When a hammer strikes the paper it makes one dot. To enable each hammer to print entire 
characters, the printbar is imbedded in a resonant mechanical system and oscillates rapidly from 
side to side. It's not hard to imagine the engineering challenges here — a new printbar with precise 
characteristics, (page 6), highly predictable resonant mechanical systems (pages 9 and 13), and 
high-speed electronics to fire the hammers at precisely the right times as the printbar reciprocates 
rapidly back and forth in front of the paper (page 18), Print quality is excellent; graphics and bar 
codes hardly look as if they're composed of dots at all (see page 20), Another advanced feature 
is described in the article on page 23, It's a new command language that will permit not only 
these new line printers but all new HP printers to speak the same language. 

In todays international marketplace, software localization is an important concern (see our 
September 1984 issue), The problem is to make computer applications software such as a word 
processing program easily translatable into languages other than the language in which it was 
written. This has to be addressed in the design of the software packages, but as the article on 
page 27 explains, it's much easier on the application designer if the system software — the operating 
system and utilities — provides features for this purpose. On the HP 3000, HP 1000, and HP 150 
Computers, these features are now standard and are called Native Language Support. Fourteen 
languages are supported, including Japanese Katakana. 

-R P. Dolan 



What's Ahead 

Four articles in the July issue will be devoted to the design stories of the HP 4951 A and HP 
4953A Protocol Analyzers. Protocol analyzers are used for checking the data transmitted between 
elements of a computer network These two are suitable for field service and computer center 
applications. A fifth article will describe PCM 0, the process control system module of HP's Semicon- 
ductor Productivity Network. 



JUNE T0B5 HEWLETT- PACKARD JOURNAL 3 
)Copr. 1949-1998 Hewlett-Packard Co. 



A New Family of Dot Matrix Line Printers 

These impact printers are designed for EDP and 
manufacturing applications. Speeds available are 300, 600, 
and 900 lines per minute. 

by Bryce E, Jeppsen 



HIAYLKTT PACKARD'S MAY J AXU1.Y ol dd matrix 
impact line printers not only offers several signifi- 
cant advantages over similar products currently 
available, hut also makes substantial contributions to HP's 
total system offering. These printers, called the HP 2563A, 
HP 2565A, and HP 2566A, Fig. 1, operate at print speeds 
of 300, 600, and 900 lines per minute (1pm). respectively. 
They are targeted for electronic data processing and distrib- 
uted manufacturing applications. 

Four key objectives of the development program were to 
minimize customer costs, significantly improve operating 
reliability, extend the performance of del matrix line 
printer technology, and standardize the system and human 
interfaces among members of the family. 

Minimizing cost was particularly important for the HP 
2563A Printer because of the extreme competitiveness in 
the low-cost end of the market. Regular project reviews 
were facilitated by modeling the product costs, employing 
the same process used in production to track the cost of 
manufactured products. Constant attention by engineers 
helped minimize parts count and assembly time. Custom 



VLSI technology, simplified mechanism design, and ad- 
vanced comprehensive packaging design made a substan- 
tial difference. Even after the printers were released for 
volume production, cost reduction efforts continued as 
new ideas were generated. 

Perhaps the most difficult objective to grasp and imple- 
ment was increased reliability. The HP 2608A/S Line 
Printer, which was to be replaced, had established a well- 
deserved reputation as the most reliable printer in its class. 
The objective for the new printers was to improve its failure 
rate by a factor of four! The road to meeting this objective 
included very careful design, thorough testing, and hard 
work. Exhaustive design reviews, the use of HP prefer roil 
parts, and over six months of strife testing in addition to 
environmental, regulatory, life, and system conformance 
testing characterized the effort (see box, page 5). The HP 
2563 A. after less than two years ol production, has achieved 
its goal. We expect the data will show a similar accomplish- 
ment for the newer HP 2565/6A as these products mature. 

Perhaps the most noticeable achievement of these new 
line printers is the performance standard they set. Many 




Fig. 1. The HP 2563 A (fore- 
ground). HP 2565A. and HP 

2566 A Line Printers are dot matrix 
impact printers that operate at 
Speeds of 300. 600, and 900 lines 
per minute respectively High re- 
liability and print quality and low 
cost of ownership were primary 
design objectives 
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Design for Reliability in the 
HP 256X Family of Line Printers 



Throughout the design and development phases of the HP 
256X Une Printers, reliability was a key focus A commitment 
was made by the project teams 10 design in reliability and so 
trough with equal emphasis on reliability in the manufac- 
turing process. Among the special efforts directed to this end 
were: (1) leveraging from earlier reliable product designs where 
possible. (2) using design reviews for new and unpf oven designs. 

(3) commftting to a test-fix -test approach to proving designs. 

(4) using a bum-;n program for early production units, and (5) 
choosing participants for the production engineering team from 
among the strongest design team members 

The tesi-fix-test and burn-in programs received special atten- 
tion and emphasis from the R&D, manufacturing, and product 
assurance departments. Each required a substantial commit- 
ment of time, material, and equipment resources, and repre- 
sented dedication to a philosophy expressed by David Packard 
in July 1972, when he stated, Reliability cannot be achieved by 
adhering to detailed specifications: Reliability cannot be 
achieved by formula or analysis. Some of these may help to 
some extent but there is only one road to reliability. Build it, test 
it. and fix the things that go wrong. Repeat the process until the 
desired reliability is achieved/' 

The test process that demanded the largest commitment of 
resources and was most effective in exposing reliability concerns 
during the development phases was strife testing— subjecting a 
product under development to simultaneous stress and life test 
conditions and Focusing attention on faifures that occur. Stress 
was achieved by operating at extremes of ambient temperature, 
applied voltage, and applied frequency, and by cycling these 
parameters between extremes. The strife test cycle is shown in 
Rg. 1 

The criterion for successful completion of strife testing was m 
least 12 consecutive cycles with no hard failures Hard failures 
are those thai would requrre a customer to call a service person 
to return the product to an operating condition. Soft failures, on 
the other hand, are those that require only operator intervention 
for correction, The concern with these was their frequency of 
occurrence under normal operating conditions. 

Soft failures were addressed in another battery of tests referred 
to as media tests, in which large volumes of paper were run 
through the printers. Data was collected on the frequency of 
failures, and iterative design improvements continued until goals 
were achieved Samples of print output from these tests were 
also collected on a regular basis and examined in detail for print 
quality. 

A third battery of tests was directed exclusively at life testing 
The biggest concern was pnntbar life Life of the printbar was 
measured in Terms of the number of impacts the hammers could 
undergo before a failure would occur. These tests began with 
early prototype machines and continued throughout the develop- 
ment and early production phases- The failure mode of most 
concern was wear on the hammer- pole impact surface to the 
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Fig. 1. The strife test cycle for HP 2563J5I6A Line Printers, 

point where the hammer would no longer be captured against 
the pole face. The design goal was 2 x 1 9 impacts and the testing 
of a recent printbar was stopped at 3 x 10 9 impacts without fail- 
ure. 

Although the combination of sirife r media, and life testing was 
central to achieving the aggressive reliability goals for the HP 
256X printer family, additionat testing was needed during the 
production ramp-up Items of concern were (1) second-tier de- 
sign-related problems that may have escaped detection in the 
R&D lab because of the statistically small number of units tested 
in the development phases, (2) vendor-related problems that 
begin to surface as large quantities of parts appear, and (3) 
workmanship-related problems that surface as newly trained em- 
ployees become involved m the production ramp -up To address 
these concerns, it was decided that burn-in testing would be 
used for all units. As in development, temperature and power 
cycling were used to attempt to accelerate failure mechanisms 
During the early production periods, each unit was subjected to 
30 complete cycles of burn-in. Failures that occurred were 
cataloged, prioritized, and addressed in priority sequence Wuh 
effective and intense action on the problems, component and 
workmanship problems have been eliminated to a point where 
it has been possible to reduce the burn-in cycling to only five 
cycles per unit, This final screening is intended to discover any 
problems that may arise as a result of changes in the design or 
a vendor's manufacturing process, 

Everett M, Baity 

Reliability Engineer 

Boise Division 



line printers are based upon a full font print mechanism, 
which means that each imparl prints h full character, Such 
printers frequently use a band technology and range in 
speed from 30U to 30Q0 lines per minute, but Imve the 
drawbacks of poor reliability, limited flexibility, and often 



poor print quality. Dot matrix printers, which offer much 
iter flexibility, multiple font styles and sizes, graphics 
and barcodes, and generally bettor and more consistent 
print quality, have been previously limited to 600 1pm 
performance. The introduction of the 900-lpm HP 2 566 A 
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has broken this barrier, offering a performance level previ- 
ously not attained by a dot matrix impact lino printer, The 
key component in this achievement is a new printbar, a 
product of five years of development. 

Paper motion control at these performance levels Is an 
extremely difficult task and represents a second major de- 
sign contribution. A third contribution is thf method of 
formatting text and symbols and generating and sequencing 
the corresponding dot images while concurrently control- 
ling the real-time mechanical operations and communicat- 
ing with the host computer system, 

A final objective was to solve a problem that has plagued 



the industry, namely that printers developed by HP and 
others are designed with features that differ from printer 
to printer. Individual printers often require special system 
instructions which are intended to optimize the use of the 
printer's capabilities. Therefore, applications written tor 
one printer usually have to be modified to vft}) k ■ m redly 
on another printer. The IIP Printer Command Language 
was developed to solve this dilemma. This protocol is used 
by all members of the new printer family. 

The articles on the following pages tell in detail how the 
design objectives were met in the HP 2F)6X family of line 
printers. 



Dot Matrix Printbar Design and 
Manufacturing 

A new captured-hammer printbar system meets 
performance needs from 300 to 900 lines per minute. 

by John S. Craven 



THE IDEAL DOT MATRIX PRINTBAR prints dots in 
precise locations, at high speed, with high energy. 
It consumes very liule power, 1 1 is reliable under all 
operating conditions, prints on a wide range of paper stock, 
and is inexpensive. 

In practice, the design of a printbar is a compromise 
among many of these requirements. For example, low input 
energy per dot and high print energy at the paper conflict. 
This article tells how these com promises were made in the 
design of the printbar for the HP 256X family ol line printers 
to provide excellent characteristics for print speeds from 
300 to 900 lines per minute. 

Design Fundamentals 

The actuator is a force-balance system; magnetic forces 
are balanced against hammer spring forces. Control of the 
magnetic forces results in the impact of the hammer with 
the ribbon to print a dot. 

The system (Fig. 1) consists of a permanent magnetic 
circuit adjacent to a hammer. The hammer is mounted on 
a surface ground at a slight angle (exaggerated in Fig. 1} 
such that the spring section is deflected by the magnetic 
force until the hammer is captured against the magnetic 
pole faces. As the magnetic force is neutralized by passing 
current through the coils, the hammer is thrown toward 
the paper by the spring force. The energy available for 
printing dots is determined by the stiffness of the hammer 
spring and the distance the hammer is cocked by the mag- 
untie circuit. The cocking distance is the focal point of the 
design. 



paper & r 1 bbor* 




magrist 



Fig, 1. Hammer actuator system of the HP 2563/5/6A Une 

Printers. 
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The force balance theory can be plotted as shown in F 'ig. 
2. The gap between the hammer and the magnetic pole 
faces is on the horizontal nd the absolute value 

of force, eilher magnetic or mechanical, is on the vertical 
(Y) axis. The integral of force times distance is energy, 
rented by the area under each cur 

The inclined straight line describes the hammea 
characteristic. At zero force, the relaxed hammer rests at 
the cocking distance from the pole surface [X inters 
The force proportional to the deflection is highest when 
the hammer is fully Clicked (Y intercept). The second curve 
is the nonlinear force imposed on the hammer by the mag- 
netic circuit as a function of the gap between them. The 
magnetic force never reaches zero as the gap opens, and is 
limited by the flux capacity of the magnetic circuit when 
the hammer is cocked. The magnetic force acts in opposi- 
tion to the spring force , but is shown inverted here for easy 
comparison. The relationship shown is a desirable one — 
the magnetic force is greater than the spring force at all 
hammer positions. This guarantees that between current 
pulses, the hammer is stable and will return to the cocked 
position. 

The motion of a hammer is determined by the net force 
imposed on it. As the magnetic force becomes greater or 
less than the spring force, the hammer responds either 
towards or away from the magnet poles. To release the 
hammer, coil current is increased to drop the magnetic: 
force curve, If the release margin is small (spring force is 
nearly equal to magnetic force j, very little current will be 
required, hut the system will be very sensitive to manufac- 
turing tolerances and wear. Such variations might G6ktl$a 
the magnetic force curve [with zero current) to cross the 
spring force curve, creating a second stable hammer posi- 
tion at the intersection of the curves. This condition is 
termed bistability. and is considered a failure, since ham- 
mer capture canimi hi- guaranteed. If the release margin is 
l.n.L',!'. current and heat dissipation demands will he high, 



but manufacturing and wear tolerances are greater. 

To maximize efficiency, the number of coil turns is 
maximized while the coil resistance is minimized. The 
resolution of this trade-off requires maximizing the copper 
volume per actuator. Coils are wound in perfect layers to 
fill the availal ! he wire size is determined by 

unpromise between ei: md speed. Large wire 

with few tur: vei inductail generates 

larger eddy currents in the poles. The coil is most efficient 
when matched to the hammer speed. 

The drive pulse is shaped to maximize hammer 
quency. Current rises quickly, then remains high until the 
hammer is far enough from the magnet poles to avoid slow- 
ing it down. While the hammer Is printing the dot. the 
current is reduced by a flyback circuit, allowing the mag- 
netic force to increase, aiding ths hammer's rebound from 
the ribbon, paper, and platen. 

To ensure uniform dots, spring energy is maximized by 
increasing cocking distance (X intercept of the spring force 
line in Fig. 2 J or spring stiffness (slope of the spring force 
line], Forms thickness, manufacturing tolerance, and wear 
life considerations favor a larger cocking distance, while 
hammer speed considerations favor a sliffer spring with a 
shorter stroke, hi either case, the sprini limit is 

imposed by Stability, as discussed above. To obtain en 
beyond the stability limit, the magnetic force curve must 
be raised by increasing the magnet strength or by improving 
the magnetic circuit efficiency to allow 7 the spring force 
line to be raised. 

This technology is being used in a number of product 
applications. The following parameter ranges are delivered 
in productions 
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Fig. 2, Under quiescent condi- 
tions , the printing hammers are 
held against the magnet faces be- 
cause the magnet force e- 
the hammer spring force. To print 
a dot. the magnet force is neu- 
tralized and the hammer is thrown 
towards the paper by the spring 
force 
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Fabrication 

The printbar is modular: coil modules form corebar mod- 
ules which, with a casting, form the corebar, The addition 
o| hammer modules completes the printbar 
Corebar Module, Compactness in the coil module de- 
creases magnetic flux leakage and increases the reliability 
of the coil connections. A laser soldering system terminates 
the very short leads of the coils on a flexible printed circuit 
without overheating the coils. Though it takes up little 
space, the flexible circuit provides electrical isolation from 
the poles and magnets, while the heavy copper in the circuit 
helps dissipate the locally generated heat. 

Bobbinless coils ensure high heat transfer to the poles, 
but are susceptible to short circuits because the bare wire 
can touch the poles. Isolation from the poles is provided 
by molding the module over core pins shaped to form ridges 
of plastic along the inside of each coil. The poles are shaped 
to touch only the ridges, and not the exposed coil wire. 
Both the coils and the poles are rigidly constrained without 
touching by the ridges and by a high-thermaJ-conductivity 
adhesive less than 0.1 mm thick between them. 
Corebar Assembly, After assembly of coil modules, poles, 
and rare-earth magnets into the casting, the front surface 
of the corebar is ground to precise form, The shape of the 
corebar surface, which determines the cocking distance, is 
generated by a diamond roll, which shapes the grinding 
wheel. 

Hammer Modules. Each module of 1 1 hammers is cut from 
a flat steel block in a broaching operation. First the large 
surfaces are shaped to generate the cross sections for the 
springs and heads, and then the individual hammers are 
separated by cutting through the blank. The precision of 
these operations determines the stiffness, flatness, and 
fatigue life of the hammers. The hammer modules are 
ground and lapped to generate the mounting interface so 
critical to uniform cocking distance. An automated drilling 
machine forms countersinks in the hammer heads, which 
receive carbide balls in an automated bail-welding 
machine. The balls are ground into pyramidal styli by a 
grooved grinding wheel, which finishes all the styli on a 
hammer module in tw r o passes. 

Printbar Assembly. The styli must be positioned within 
0.05 mm in two dimensions. The HP 2563A printbar has 
a single row of 33 styli, so the alignment is simple. The 
HP 2 565/6 A Printers, however, have two interleaved rows 
of 66 styli each, which must align when they impact the 
paper- Therefore, the styli are intentionally misaligned 
when cocked to allow for the curvature of their flight paths. 

Testing 

The flatness and stiffness of the hammer are measured 
together in a special fixture. The hammer module is held 
by its mounting surface to mimic functional mounting. 
Noncontacting capacitance probes are used to measure the 
hammer positions before and after a known mass is lowered 
onto the hammer at the predicted center of magnetic force. 
The kinematics of the hammer/spring system are calculated 
from the measured data. 

Corebar surface geometry is measured by an automated, 
self-calibrating test system, which scans the surface of each 
corebar with multiple sensors to determine the profiles of 



the intersecting planes. The system calculates the angles 
between surfaces and their points of intersection along the 
length of the corebar. The resolution is 0.25 micrometers, 
so the slightest deviations from nominal can be detected 
and displayed graphically for immediate feedback to the 
grinding operator. 

The hammer and corebar surface data allow production 
operators to control the spring force line |Fig, 2). 

Although bare magnets are sample tested accurately, in- 
corebar testing is sometimes necessary to determine the 
cause of performance changes. When the coil in an actuator 
is driven to produce a zero flux reading in a special sensor 
above the pole surface, the effects of the poles and their 
interface with the sensor become negligible. Thus, we can 
get an indication of the strength of the magnet independent 
of the poles by measuring the current required to null the 
flux. With the magnet strength known, the performance of 
the poles alone can be implied from a measurement of the 
flux without current. This indicates, for example, whether 
the case hardening of the poles was done correctly. 

System Performance 

The interactions of the individual tolerances are evalu- 
ated by an automated test system. This 100% production 
test drives the print actuators and measures position and 
coil current to reconstruct the theoretical curves {Fig> 2). 

Printbars are tested indirectly for only the critical points 
of the curves: the release point, the capture point, and the 
cocking distance (see Fig, 3), The test system gradually 
increases current through the coil under test, lowering the 
magnet force curve until the hammer releases. This release 
current is an indication of the energy required to fire the 
hammer. The test system continues to increase the current 
until the hammer reverses direction because of magnet flux 
reversal. The maximum hammer excursion indicates the 
cocking distance. Then the current is decreased, raising 
the magnet force curve, until [he hammer suddenly jumps 




Release 
Current 

Capture 
Current 



Time 



1 Second 



Fig. 3, Hammer position and magnet coil current during test- 
ing of a hammer for release current, cocking distance, and 
capture current. 
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toward the magnet poles, The current at that point is the 
capture current. 

The capture current is significant because it indicates 
not only the present state of the actuator, but also its poten- 
tial life. As a print actuator wears, metal is removed and 
the cocking distance increases. The spring force curve shifts 
toward the right [i itid the force margin decreases. 

Extensive testing has shown that, by a combination of non~ 
linear effects, the capture current is a linear function of 
normal wear. After a break-in period, the life of a test bar 
can be predicted far in advance of actual failure. Data from 
such life tests was used to determine the minimum a I low- 
capture current for production prinibars to assure a 
life of at least 2x10'* dots. 

Conclusion 

The modularity, size, efficiency, and speed of the ac- 
tuator make it adaptable to a wide range of applications. 
This printbar technology has been incorporated in all mem- 



bers of the HP 256X Printer family. It is used to print text 
and graphics on paper stock ranging from single-part paper 
\-part forms and heavy labels, The fabrication param- 
eters can be adjusted to obtain a range of combinations of 
speed, print force, life, and print gap. 
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Shuttle System and Packaging of a Low- 
Cost, High-Reliability, 300-lpm Line Printer 



by Jeffrey M. Lantz and Ben B. Tyson 



IN DOT MATRIX LINE PRINTERS, the printing device 
(the printbar] oscillates horizontally with a frequency 
and displacement determined by the throughput require- 
ments, the number of hammers used, and the number of 
dot rows in the character cell. Designing an oscillatory 
shuttle mechanism for such a print ri presents interesting 
problems in dynamics and stress analysis- In the case of 
the HP 2!>63A Printer, stringent requirements of sirupl is itv 
and reliability guided the design of the shuttle mechanism. 
The printing process requires the printbar to oscillate at a 
frequency of 18 Hz. Oscillation of the printbar with a 
sinusoidal velocity profile was chosen because this type 
of motion is easy to obtain using a spring mass system. 
Operating in .1 resonanl condition minimizes the power 
required to drive the shuttle system. Along with the reduc- 
tion in power comes a reduction in the shuttle driving 
OS, which increases the reliability oi the mechanism. 
The printbar shuttle mechanism (Fig. 1) consists of two 
masses (the printbar and counterweight), their mounting 
flexures [E-flexures for the printbar and standard flexures 
for the cou nter weigh t|, and the electromechanical drive 
[dc motor, crankshaft, and flexible connecting rods), 

The shuttle mechanism operates at resonance with the 
printbar ami couoterweighl initial forces canceling each 
other. While the printbar resonant system could work with- 
out the counterweight, forces caused by the accelerating 
printbar would be transmitted to the stand or tablelup and 



would be unmanageable. The addition of the counter- 
weight, also driven at resonance but 180 degrees oul i>i 
phase with tin- printbaj balances the inertial forces of the 
printbar (Fig. 2). A small inert ial moment is generated, 
I iow ever, because the centers of mass 0! the j.irinlbar and 
counterweight are not precisely in line. 

Flexure Stresses Determine Size 

The counterweight has twice the mass and oscillates M 
one half the displacement of the print I mi This proves 
necessary because space constraints allow counterweight 
flexures of only 1U8-miu length. With this length and a 
counterweight displacement equal to the printhars. the 
stress in the flexure would have been too high for a laru. 1 
life of 10 H cycles. The equation defining the counterweight 
flexure stress as a function of mass is; 

ffs/o-! = n~ 2/A 

where n is the ratio of the counterweight mass to the 
printbar mass, cr, is the stress for n - l t and o\, is the stress 
for a mass ratio of n. 

This equation assumes a resonant counterweight, with 
the displacement of the counterweight equal to llie dis- 
i ! 11 ement of the printbar divided by n. From Fig, 3, It can 
hi: seen that the flexure stress for n = 2 is (i3% of the stress 
for n = 1 . 
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Counterweight 
(Cutaway) 

/ 



E -Flexure 




E -Flexure 



Connecting Rod 



Fig. 1 » The shuttle mechanism of 
the HP 2 563 A Line Printer consists 
of the print bar and counterweight, 
their mounting flexures, and the 
electromechanical drive. Flexible 
connecting rods connect the 
crankshaft to the printbar and 
counterweight. To keep the cost 
low, the connecting rod material 
is molded around the bail bearing. 



A mass ralh) of 2 wus chosen because that is where the 
si i ess in the counterweight flexures equals the stress in the 
E-flexures. Also, the density of the Zn-Al alloy used for 
the counterweight created a mass ratio limit near 2 because 
of the volume available. 



in forming the characters. The effect would have been seen 
as scalloping of the horizontal lines. The E-flexures reduce 
the crowning because the short and long flexures nearly 
cancel the each others' effects. The short flexures raise the 
printbar and the long flexure lowers it (see Figs. 5 and 6). 



E-Flexure Design 

The printing process requires a printbar displacement of 
±5.0 mm- This displacement introduced the problem of 

cruivning; as a Ilex u re is displaced , its effective length is 
shortened [Fig-, 4). Crowning can be approximated by: 

M' = l/ 2 f (dy/dx)Mx - 0.6 j- 

In this equation, dy/dx is the slope of the deflected flexure 
curve, 1 is the flexure length, and y is the flexure deflection. 
For a displacement of 5 mm, the crowning would have 
been 0,1 3 mm with a standard flexure [Fig, 4), This amount 
nl i rowning is nearly one half the vertical dot spacing used 




weight 
Flexures 



n — [r 



Crankshaft 

Flexible 

Connecting 

Rods 

DC Motor 
77 



Fig. 2. Mechanical schematic diagram of the shuttle mecha- 
nism 



Flexible Connecting Rods 

Flexible connecting rods are used to connect the 
crankshaft to the printbar and counterweight. This ap- 




Fig. 3. Stress ratio versus ratio of counterweight mass to 
printbar mass. Stress ratio is the stress in the counterweight 
flexures for a given mass ratio divided by the stress for a 
mass r&tto of one 
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r- T—r 




0,13 mm 




Fig. 4. Crowning of a flexure; as the flexure is displaced, its 
effective length is shortened 

proach simplifies the design by requiring only two bearings 
instead of four, The connecting rod material is molded 
around the hall bearing to keep costs low. The bearing is 
placed in the molding tool and glass-filled nylon is injected 
around it. As the plastic cools T it shrinks to constrain the 
bearing tightly [Fig. ]). The bearing and the flexible con- 
necting rod oan ncnv he pressed onto the crankshaft. 

Startup Algorithm 

During printing, torque and motor current are kept low 



Fig, 5. t-fiexures reduce crowning The short flexures raise 
the prmibar and the long flexure lowers it, and the effects 
tend to cancel. 

because of the resonant system. Only 10 watts of power is 
required to drive the shuttle system. However, the startup 
torque required is much greater than the running torque 
To keep the motor small and the electrical drive nirvpen- 
sive, a special algorithm is used to start the mechanism 



S9S5 



Standard Flexure 




E-Flexure 



ht^ ' ^.s 



_L 



+ 1 . a • a . a 



*3.a M,a *¥j 






Fig. 6. Crowmng of standard and 
E -flexures, 
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Fig. 7, 

motor 



This starting algorithm a Hows the use of a smaller 



[]F1g; 7). Implemented in control processor firm ware, the 
algorithm can turn the motor on and off and set the voltage 
supplied to the motor. The firmware requires two bits of 
information; a printbar direction signal from the encoder 
and the sign of the back EMF from the motor. The encoder 
determines the direction of the printbar motion, The sign 
of the back EMF indicates whether the motor is turning 
clockwise or counterclockwise. 

The firmware initially turns on the motor and senses 
when the direction changes, The first direction change will 
occur because the motor cannot overcome the static torque, 
so the shuttle system, which has started to move, begins 
to return to a static equilibrium condition. As soon as the 
direction changes, the motor is turned off and the back 
EMF read to see it the motor is rotating in the same direct ion 
or has reversed. If the rotation has reversed, the firmware 
waits for one more direction change and then turns on the 
motor again. This process of pumping more energy into 
the system continues until the back EMF indicates that the 



motor is rotating continuously in the same direction and 
not reversing itself. This startup procedure takes approxi- 
mately 1(H) ms. 

Packaging 

The cabinet for Ihe HP 25f33A Printer has to make the 
printer quiel while providing necessary openings for ven- 
nl.iHon and paper input and output. When the printer is 
usee! on a tabletop, the paper enters through a slot in the 
lower front. When used on the enclosed stand, an alternate 
paper path is provided through the bottom, allowing the 
front slot to be sealed off acoustically. The paper exits the 
back of the printer to move the noise source farther from 
the operator, Possible acoustic leaks between the main 
cover and the access cover are sealed with a gasket ed 
longue-aod-groove detail. The print mechanism is isolated 
as much as possible from the eleclronics (where ihe heat 
vents are located) to prevent noise generated by tin j printing 
process from escaping the package. An impeller is added 
to the rotor of the ribbon drive molt ii I p provide the cooling 
needed in ihe print mechanism. 

Structural foam was chosen for die cabinet material be- 
cause of its strength and acoustic properties. Structural 
foam gave us the ability to mold in fine details like keepers 
for the draw catches, card guides, and cable routing clips 
The strut; I era I Integrity of the foam is particularly impor- 
tant, since the hinge/gas-springmounl detail is molded into 
Hie covers. The main cover and the access cover have the 
hinge pins and holes molded in. eliminating the need for 
a separate hinge and associated mounting hardware, The 
gas spring serves to keep the access cover from slamming 
closed and prevents its being raised to a position that would 
aliow r it to be removed. 

The operator panel, which is shared by all 2 5BX Printers, 
uses a silicone rubber keypad. Electrical connection is 
made when the conductive pads attached to the bottoms 
of the keys contact the serpentine traces on the underlying 
printed circuit board. A thin membrane at the bottom of 
each key provides the snap action. The bezel is molded in 
a conductive plastic for electrostatic protection 

The top-level assrmhk time is minimized since the print 
mechanism mounts with only three screws, the major elec- 
tronic parts snap or slide into the base, and the fan is 
sandwiched in place when the cover is installed. 
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Mechanical Design of a Family of High- 
Speed Impact Line Printers 

by George V, Mcllvaine, Stephen L. Testardi, Daniel D. Wheeler, and Peter Gysling 



IMPACT PRINTERS generally have more moving parts 
than other peripheral devices, and I he HP 2565A (600 
lpm J, and HF 2566A (900 Ipni) are no exceptions. 1 
are also some of the physically largest products that Hew- 
lett-Packard offers. 

The HP 2565/6A Printers move paper at high speed past 
a bank of 132 interleaved hammers which are mounted on 
a resonant reciprocating printbar, A towel ribbon carrying 
ink passes between the paper and the styli* which are at- 
tached to the hammers. 

Interleaved Hammers 

In conventional serial printers, print wires arranged in a 
vertical line each print one horizontal dot row as the print- 
head is scanned across the page. In a dot matrix line printer, 
the hammers are equally spaced in a horizontal line across 
the width of J he page, and each hammer has the function 
of printing all ol the dots within its cell. A ceil is defined 
as a vertical band of a given width centered about each 
hammer. By reciprocating the hammers across their cells 
and subsequently advancing the paper t each hammer can 
be made la print an out ire character. When the cell width 
ls <-M.jiiat to the hammer spacing, a dot can be placed any- 
where on the page. Fig. l compares the formation of the 
character A by a serial printer and a dol matrix line printer. 

Tlie speed of a dot rnalrix line printer is limited by both 
the number of hammers and the maximum rah* at which 
iIr'Y can be actuated. Many dot matrix line printers use 
from 33 to 66 hammers to print a standard 13. 2- inch-wide 
pagfij but their speeds have been limited to 6Q0 I i 1 1 ■= •-■■ p0] 
minute (1pm). To achieve print speeds of op to 900 1pm. 
the HI' 2565 6 A Printers use print bars with 132 hammers 
spaced on 0.1 -inch centers, The hammer design requires a 
minimum horizontal spacing of 0.2 inch, but by interleav- 
ing an upper and a lower row of hammers, an effective 
I). 1 -inch Spacing is achieved [Fig, 2), 



to move in a nearly parallel relationship with each other 
and the print mechanism, The driving force is applied to 
the system through the linear motor, which consists of a 
.H with an annular air gap. A cylindrical motor coil 
(much like the voice coil of a loudspeaker) is attached to 
the printbar and extends into the air gap. Current flow 
through the coil exerts equal and opposite forces on the 
motor and the printbar. 

The thicknesses of the flexures are selected so that both 
the printbar and linear motor are resonant at the proper 
frequency- Because of the high spring rates involved, ex- 
tremely high forces would be required to drive the system 
at anything other lhan its resonant frequency, (A static 
force of 54! newtons would be required to displace the 
printbar to the outermost bound of a character cell!) To 
minimize drive power requirements, the system is driven 
at resonance, with the printbar and linear motor moving 
colinearly and 180 degrees out of phase. If the linear motor 
is tuned to exactly the same frequency as the printbar, the 
the resultant force transmitted to the print mechanism is 



Printwires 
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)► Printhead Motion 
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Resonant Printbar Dynamics 

One of the primary mechanical requirements of the HP 
2565/6 A Printers is a means of reciprocating the printbar 
so that each hammer can print anywhere within [tfi cell. 
This must be done while maintaining a constant hammer- 
to-platen gap within ±0.01 mm. Reciprocating a printbaj 
becomes more difficult as the mass of the bar and the fre- 
quency and amplitude of reciprocal inn increase. I -'or tint 
HP 2 566 A to print at 900 lines per minute with graphics 
capability, it is necessary to reciprocate a 3-kg printbar at 
60 Hz. with peak-to-peak amplitudes of at least 0/1 inch. 

The method chosen to accomplish ihis is shown in Fig, 
2, The printbar is mounted on a pair of leaf springs or 
flexures. A linear motor is mounted op four flexures beside 
the printbar. The flexures constrain the printbar ami molur 
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Fig. 1 . Formation of the character a by a serial printer (a) 

and a dot matrix fine printer (bj 
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Fig. 2, The HP 2565f€A pnntbars 
have 132 hammers spaced on 
0. 1 -inch centers. Upper and tower 
rows of 66 hammers each are In- 
terleaved. 



theoretically zero. To allow for real-world variations, the 
print mechanism is mounted on compliant bushings to 
isolate it from the printer frame. Because of the sharp reso- 
nant peak of the mechanical system, a resonance search 
technique is employed by the control processor at power-on 
or reset to ensure that the system is always driven at reso- 
nance regardless of minor changes or variations in physical 
jjHEiiinrlers [see box, page 17], 

The system is cuj it rolled by a velocity feedback loop. A 
velocity transducer between the printbar and the print 
mechanism provides a feedback signal, which is summed 
with a digitally generated control signal to yield a velocity 
error. This signal is compensated slightly to avoid high-fre- 
quency instability problems and then fed to the linear 
motor amplifier. Printbar position information is provided 
to the printer control processor by integrating the velocity 
transducer output. 

The advantages of such a drive scheme are numerous. 
There are no wear points that require lubrication and the 
life of the mechanism is essentially infinite with no 
periodic rjafiintenaiu e required. The power requirements 
and weight are less than those of a cam-follower system. 
The amplitude of reciprocation can be adjusted pro gram- 
matically to optimize printer performance* and an entire 
family of printers can be leveraged by changing the fchil k- 
ness of the printbar and motor flexures to yield different 
resonant frequencies for different-speed printers. 

Towel Ribbon Control and Correction 

Although towel ribbons have been used in impact print- 
ers for many years, the HP 2565/6A Printers are the first 
Hewlett-Packard-designed printers that use them. All ear- 
lier HP designs use ribbon cartridges, which deploy a thin 
band instead of broad spools of inked nylon. 

Control systems for towel ribbons are well-documented 
and will not be explained here. However, during develop- 
ment of these printers, a problem arose with bunching and 
wrinkling of the towel ribbon near the print area. Small 
wrinkles would propagate through the ribbon web. branch- 
ing and merging to form larger wrinkles, which eventually 
became a tight localized foldover of ribbon on the take-up 
spool. Uncorrected, the foldover would increase in severity 



until protective electronic circuits turned the mechanism 
off. Many solutions, including changes to the circuits limit- 
ing the ribbon drive motor torque, additional ribbon posi- 
tion sensors, and fundamental ribbon control system re- 
structuring were proposed. These electronic solutions, 
however, did not address the underlying cause of the prob- 
lem, which was the formation of wrinkles in the ribbon 
web. Eventually, a simple mechanical change completely 
solved the problem. 

{conlinued on page 17) 
Bowed Guide Rod (shortened to exaggerate the crown) 



Thin-Walled 
Cylinder 




Ribbon moves 

towards print 

area 



Ribbon is dewnnkled 
as it passes over 
bowed guide rod 



Aluminum End 
of Ribbon Tab 

Supply 
Spool 

Fig. 3. The towel ribbon is dewrinkted as it passes over a 
bowed guide rod 
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Computer Modeling of a Paper 
Drive Mechanism 



In the HP 256? r inters, the paper is advancec 

the prrntoar is changing directran Based upon the desire 
speed, The fastest expected hammer speed, and the dynamic 
limitations of the paper drive system, the time available to step 
the paper is 4 ms, A step motor was chosen to dnve the paper 
teed tractors because of its accuracy and its adaptability to 
reliable open-toop control The torque of a step motor varies with 
the position of the rotor and the current in the windings. The 
torque-versus-posilion relationship is a series of sinusoidal 
curves (Fig 1). The motor is stepped by switching from one 
torque curve to another The printer firmware does thrs by turning 
the windings of the motor on and off and changing the c 
to the windings, 

In doing a full step, the motor will overshoot the desired step 
by about 90% of a step and then oscillate about the desired 



position until it finally comes to rest This nnging effect is charac- 
teristic of step motors and needs to be damped to achieve proper 
paper motion There are se vera : this, but one method 

is by giving the motor two haff-steps rather than one full step 
The currents ar--_. rig of the two half-steps are selected 

so that the motor increments one full step ;ery quickly without 
any ringing. 

Step current, hold current, and Oe^ay-io-nold are the 
parameters that make up a step sequence The step current and 
the hold current determine the peak vaJue of the smsusoidai step 
torque and the hold torque curves The deiay-to-hold is the time 
between the start of the first half- step and the start of the second 
half-step. 

A computer model of the dynamics of the paper drive system 
was developed and compared with the actual printer The modet 
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Fig. 1 , Torque versus position for 
the step motor used m the HP 
2565/6 A paper dnve mechanism 
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Fig, 2. Model of the pap?.- 
mechanism 
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used the Runge-Kutta method to solve the equations that de- 
scribe the paper drive system (Fsg 2). On an early breadboard 
printer, the model and the actual data compared very closely. 
The dot placement accuracy of the breadboard resulted in print 
that was readable but not as good as desired. That performance 
served as the limit for the print qualily specification. Input vari- 
ables used by the model were changed to see what efteci ihey 
would have on the paper motion, A subsequent design change 
achreved greater dot placement accuracy. The data from the 
new design matched the predicted behavior from the model fairly 
closely. The final analysis showed (he paper motion to be accu- 
rate to ±0.0015 inch as shown by both the data and the model 
(see Figs. 3 and 4) 

Peter Gysfing 

Development Engineer 
Bosse Division 




Fig. 4. Actual paper and encoder positions agree well with 
model data. 
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(conimued from page l - ; 

Fig. x3, page 14. shows how the propagation of web 
wrinkle is corrected. The ribbon passes over bowed guide 
rods, which substantially dewrinkle the web, The guide 
rods are positioned on both sides of the hammer bunk. 
adjacent to the ribbon spools. Because the ribbon reverses 
direction at the end of its travel, the guide rods serve to 



Resonance Search Technique 



The control processor tests and tunes the servo system that 
dnves the printbar during power-up or reset to determine rhe 
resonant frequency of the print mechanism A setf-test is first 
executed to check out the print servo system. A failed test reports 
an error to the operater panel and host computer and prevents 
the servo from entering a print ready state. A passed test allows 
the print mechanism resonance search process to begin. The 
printbar reciprocating frequencies for the two HP 2565/6A Print- 
ers are different. The nominal frequencies are: 40 Hz {HP 2565A) 
and 60 Hz {HP 2566A) Because of uniMo-unii variations, printers 
deviate slightly from these established nominaf values; yet each 
print mechanism must be driven at its actual resonant frequency 
Hence, the control processor must be able to determine the 
minimum-power operating frequency for the parlicular printer 
The process of doing ih*s is called tunmg 

Tuning begins by forcing the servo system off and then apply- 
ing a short-duration disturbance to emulate an impulse After a 
short delay to permit higher-frequency transients to die out, the 
period of the damped sinusoid response is measured. The mea- 
sured frequency constitutes a rough guess that ts used as a 
starting point for a subsequent fine-tune gradient search over 
neighboring frequencies until the minimum-power operating fre- 
quency has been found This frequency is used until the next 
power-up or reset cycle 

Gary W. Green 

Development Engineer 

Boise Division 



Fig. 4. Power tractor positioning 
of the HP 2565/6A Line Primers 



smooth the web both when it is supplied and when it is 
taken up by the spools. Another advantage of the system 
is that the ribbon is dewrinkled before it passes by the 
hammers, which improves print quality and prevents fold- 
ing of the wrinkles \vhen the hammers strike the web. 

The guide rods are bowed by means of two small shims, 
which offset two thin- walled cylinders mounted around a 
stiff inner rod. A shoulder insert supports the tubes in the 
middle of the rod, creating a central crown. The slope of 
the crown was determined empirically to minimize wrin- 
kles in ribbons of varying ape. The tubes are electric.. il I \ 
isolated from each of lit t and also serve as end-of-ribbon 
sensors. When the end of the ribbon is near, a flexible 
aluminum foil patch glued to the ribbon contacts both tubes 
simultaneously and causes I he ribbon drive motors to re- 
verse direction 

Open-Throat Paper Path 

The printer-operator interface is improved by ninaus ol 
the open-throat paper path geometry used in the HP 2585 
h\ Printers. The print mechanism consists of two major 
assemblies: the lower casting and the swing gate- The lower 
casting con tains the tractors, power tractor positioning sys- 
tem, and paper guides, The swing gate includes \\w 
printbar, linear motor, and ribbon drive system, 

The swing gate can be swung up out of the way when 
the operator requires unobstructed access to the paper path 
for loading. Because there are four tractors, the waste of 
prenumbered forms can be minimized. When the last form 
in one box has been printed, the form is stopped between 
the upper and lower tractors. Here the top form of the next 
hu\( .in Iim spliced tut he previous form for cunt huiad print- 
ing. With the swing gate in the up position, the operator 
l ,iin also adjust the tractors to the correct width for the form 
being printed. 

The paper path is sli^htlv curved lo provide a smooth, 
gradual transition from the lower tractors to the upper trao 
hav This characteristic; helps minimize the number of 
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paper jama. 

The optimum paper viewing angle for an operator stand- 
tag at the front of the printer is approximately 30 degrees 
from horizontal. This angle For the upper tractors works 
very well in creating a jam-free exit path for the paper, 
primarily because the paper is being directed at a low 
enough angle to keep it from lifting off the paper guides at 
high paper slew speeds. 

The angle of the lower tractors was chosen with two 
constraints. One was to pull the paper out of the box as 
directly as possible to minimize paper ieerl problems. The 
second was to keep the angle between the upper and lower 
tractors as small as possible to decrease the chances of 
paper jams in the throat area, 

Power Tractor Positioning 

Because the HP 2565 B A Printers have four tractors, a 
system had to be designed to adjust the tractors for different 
form widths and to position the paper properly in the 
printer while maintaining precise vertical alignment of the 
tractors. This is accomplished by the use of cables^ an idler 
mechanism, and a drive motor (Fig. 4). 

The left and right tractor pairs are connected to separate 
figure-eight cable loops. The cables allow independent 
horizontal motion of I he left and right pairs while forcing 
the upper and lower tractors in a pair to move together, A 
spring is inserted in each figure-eight loop to provide ten- 



sion and compensate for any stretching of the cable. Two 
drive pulleys are coupled to a reversible motor by a com- 
mon shaft, Each cable is wrapped around its respective 
drive pulley so that rotation ot the drive motor shaft causes 
the tractor pairs to move. A spring-loaded cable idler mech- 
anism can release the tension on one cable while also ap- 
plying a brake so that the left tractors remain stationary 
while the right tractors move to adjust for form width. Once 
the correct form width has been set, I he cable idler and 
brake are released so that all four tractors move together. 
The tractor pairs can be moved in either direction and 
at two different speeds, A fast speed is provided to make 
coarse paper position adjustments, while a slow speed is 
provided for fine adjustments in paper position or horizon- 
tal paper tension. 
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Cost-Effective, Versatile Line Printer 
Electronics and Firmware 

by Philip Gordon, Phillip FL Luque, and Donald K. Wadley 



ELECTRICAL DESIGN of the HP 256X family of line 
printers emphasized close coupling between the 
electronics and the firmware to meet the cost, flex- 
ibility, and performance objectives. The digital control 
electronics consists of the I/O, control processor, and dot 
generation logic (DGL) sections. Data passes through the 
I/O system, is formatted by I he control processor, and is 
finally converted to properly sequenced dots for the print 
mechanism by the DGL (Fig. 1). 

Each I/O interface is a separate printed circuit assembly 
that consists of not only the specific interface electronics 
but also a Z80A microprocessor, firmware ROM, and RAM. 
This system converts protocol specific information into a 
universal format expected by the main control processor. 
Interfaces may he exchanged easily without modifying or 
reconfiguring main control processor firmware. Interfaces 
available on all HP 256X Printers include RS-232-C, RS- 
422-A. and multipoint serial interfaces, and HP-IB (IEEE 
488 ] T differential, Centronics, and Dataproducts parallel 



interfaces. 

The main control processor system includes the micro- 
processor, firmware ROM and RAM, along with interrupt 
control, timing, and bus interfacing support electronics. 
The microprocessor components used are the Z8QA (HP 
2563A) and the 8088 (HP 2565A and HP 2566A). All print- 
ers share the identical operator panel assembly and manner 
of use, 

Processor Firmware 

Control processor firmware is divided into logical and 
physical printer firm ware. Logical firmware, written 
primarily in a high-level language, is the personality of the 
printer that is visible to the user and host computer. It 
receives the data and control information from the I O 
tern, performs the requisite escape sequence parsing, for- 
mats this into logical print data lines, and places the result 
in a queue for future printing. The logical firmware, how- 
ever, has no knowledge or control over how this formatted 
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Fig. 1 . Dot generation logic and hammer driving circuit block diagram. 



information is ultimately printed by the mechanism. It is 
the physical firmware that accepts the queued print data 
and performs the detailed operations to complete ihe print- 
ing task; These functions include synchronizing ali elec- 
tronic and mechanical systems of the print process, setting 
up the DGL In convert I his information into properly .se- 
quenced dots, programming the dot position encoding sys- 
tem to ensure correct hammer firing, establishing printbar 
motion requirements, stepping the paper, and so on, The 
physical firmware, written primarily in low- level micro- 
processor instructions, is optimized for the electronics and 



mechanisms in the specific printer. Although the physical 
firmware is nearly identii . t \\ for the similar HP 2565/fiA 
Printers, it is very unlike that of the fundamentally different 
HP 25J63A Printer, 

Self-test firmware is also divided within the logical and 
physical firmware spaces. Self-lest structuring, digital 
hardware tests, print pattern testei and other leveragable 
median ism -independent functions are about 80% of the 
self-test and are located within the logical firmware. The 
remaining mechanism-dependent functions, such as the 
printbar tuning process (see box, page 17). are placed 



Comparator 




Control 
Processor 



hre Signal 
--► to Hammer Fire 
Circuit 



--« 



Integrator 



Sine Wave 
Generator 



Drive Level Feedback 



veto* 
^^fl Transc 



Comparator 



Vetociiy 
ansducer 





MOSFET 

Drive 



+50V 



-4 




Current 

Sense 

Resistor 



Fig. 2. HP 2565i6A servo system 
controls printbar motion and ham- 
mer firing. 



J 1 INI.. 1985 HEWLETT-PACKARD jOUHN/ 19 



)Copr. 1949-1998 Hewlett-Packard Co. 



Vector Graphics for Dot Matrix 
Printers 



An optional printed circuit assembly, the HP 26061 A, 
plotter-like vector graphics capability to the HP 256X family of 
dot matrix One printers. This option net only frees the host com- 
puter from computalionnntensive vector-to-rasrer conversion, but 
it also does these conversions much more quickly because it is 
specifically designed for this purpose. 

The heart of the HP 26061 A >s the y.PD 722G graphics display 
controller (GDC) chip, which can convert singJe-dot-wide vectors 
into their corresponding pixels at a rate of up to 750,000 pixels 
per second The GDC sets the pixels in a dynamic RAM bit map 
Once a graph is completed, the dot image is sent to the HP 
256X DGL (dot generation logic) to be printed at either 70 dpi 
resolution for hjgh speed or 140 dpi resolution tor high quality 
There are two versions of this option; one has a 128K-byie bit 
map and the other has a 5l2K-byte bit map The 128K-byte 
version can create a maximum 13. 2-by-1 5,6-inch graph at 70 
dpi. or a 7 3-by-7.l-inch graph at 140 dpi The 512K-byie version 
can create a 1 3.2-by-62 7-inch graph at 70 dpi, or a 1 3 2-by-i 5 6- 
inch graph at 140 dpi, Other sizes can be programmed as long 
as the graphs have the same number of pixels. Because the 
GDC is only used \o draw single-dot-wide lines, an 8058 micro- 
processor breaks down all the high-level graphics commands 
into Sfngle-dot-wide lines, The microprocessor requires 48K 
bytes of assembly language code because of the high level of 
graphics functionality supported- Running in parallel, the GDC 
and the 8088 can co nven up to 700 vectors per second The 
HP 26061 A receives vector graphics commands from the host 
in a format that is modeled after the emerging ANSI computer 
graphics metafile standard (dp ANSX3.122. Information Process- 
ing Systems Computer Graphics Metafile for the Storage anci 
Transfer of Picture Description Information) It supports a high- 
level set of graphics primitives including tines, circles, arcs, poly- 
gons, area fills, markers, and text. A large number of attributes 
may be set to alter the appearance of these graphics primitives. 
These attributes include line width, line style, perimeter width, 
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perimeter style, fill style, and text size, orientation, slant, direction, 
and alignment (see Fig. 1). In addition, the HP 26061 A supports 
mapping and scaling transformations and clipping, 

Sharon E, Jones 

Alvin O, Schoften 

Development Engineers 

Boise Division 



within the physical f i rm w a re s pace . 

Logical firmware leverage and ease of system integration 
are the two principal benefits of dividing the control pro- 
cessor firmware in this way. Since the logical firmware is 
essentially Independent of the print mechanism and the 
choice of I/O interface, it was quickly and easily transported 
to the different printers of the HP 256X family. This ensures 
feature compatibility between different members of the 
family. 

System integration and conformance lesling me the ex- 
tremely important, yet time-consuming tasks that verify 
proper printer operation with a myriad of supported com- 
puter families and system configurations. Once the logical 
firmware has been verified to meet all published specifica- 
tions for one printer, subsequent printers employing the 
same logical firmware can be tested more rapidly but no 
less exhaustively. 

Dot Generation Logic 

The main control processor does not have the bandwidth 
to convert the ASCII or otherwise ended data into a corre- 
sponding dot image or to sequence these dot images prop- 



erly for the hammer drivi rig electronics/Hie state-machine- 
controlled DGL system performs these tasks. The universal 
DGL system needs to be very low- cost for the HP 2503 A 
Printer and high-speed for the HP 2566A Printer. Because 
DGL systems have historically required a painful number 
of standard TTL components, ours is implemented using 
VLSI technology. 

Since all available character fonts are stored in ROM 
adjacent to the DGL, generation of the proper font dot im- 
ages is a simple and rapid lookup process, Sequencing and 
ordering these dot images for the hammer driving elec- 
tronics is a much more troublesome task. Although dot 
matrix impact line printers appear to print a single dot row 
at a time, the hammer driving circuits cannot collectively 
accept simple raster-scan dot data as a video display unit 
does. As the printbar on the 1 32-hammer HP 2565/6A Line 
Printers moves from one extreme position to the other, 
each hammer passes across its exclusive 0.1 -inch- wide 
print urea. Since this printbar covers 13.2 inches of paper 
at a maximum dot resolution of 210 dots/inch {dpi) for a 
total of 2772 dot positions, the first 132 dots printed simul- 
taneously are scattered 2 1 dots apart within the row. The 
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next 132 dots printed simultaneously are still 21 dots apart 
but adjacent to the previous ones, Therefore, the printbar. 
viewed as a unit , appears as a group of 1 32 disjointed raster 
scans. Dot image data must be ordered to compensate for 
this printbar geometry. For today's versatile line printers 
that provide variable dot resolutions and multiple character 
pitches, and allow character or bar code element pif 
to change within a print row. the amount of arithmetic and 
needed to perform dot sequencing is substan- 
tia]. 

The solution for the HP 256X family of line printers is 
a smart shift register that acts as both a full line buffer and 
an automatic dot sequencer. This shift register is 2772 bits 
long, one storage cell for every dot that can be placed across 
a print row. It also has 132 output taps spaced every 21 
bits along its length — one tap for each hammer in the 
printer. The number of storage cells between the taps equals 
the maximum number of dots each hammer can reach and 
print in a pass of the printbar. This shift register accepts 
simple raster-scan data because it precisely complements 
the geometry of the printbar. The DGL easily fills this shill 
register with the entire dot image for the row during the 
nonprinting printbar turnaround time, Then this shift regis- 
ter is clocked once each time the hammers are activated 
to bring the next set of printable dots to I he taps. 

The VLSI Solution 

Large standard slatic shift registers are unsuitable for 
such an application since they are accessed serially and 
no taps are provided , A custom VLSI component is reqi i 
to make this design an economic realily. But since a 132- 
hu miner line printer requires as many output taps, a VLSI 
component would immediately encounter a costly packag- 
ing problem. To limit package pins, an integral 132-bit 
parallel -to-serial output shift register (Fig. 1) is loaded from 
the taps of the main shift register and is then repeatedly 
clocked to shift this data serially into the hammer driver 
shift register* This output shiil i> v.i m i is bidirectional to 
help accommodate the two print motion directions. When 
this VLSI component is used in the :n-h;mmier Ml 3 25S3A 
Printer, b divide-by-four circuil stores every fourth bit from 
the output shill noisier into the J:s-bit hammer driver shift 
register, Proper synchronization guarantees that the other 
99 output bits are discarded. The VLSI component appears 
as the same 2772-bit main shift register with only 33 useful 
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taps now S4 bits apart, with a 33-bit output shift register. 

The HP NMOS-C process was selected for its low cost 
and adaptability to full custom circuit design. Circuit de- 
sign and mask layout were done by HP's Boise Division, 
while part fabrication is done by the Cupertino IC Div i 
A 2772-bit single-direction main shift register is combined 
with a bidirectional 132-bit output shift register to limit 
kage pins to 16, Design expenses and risks were 
minimized because the chip layout is a repetitive series of 
several varieties of shift register cells. Depletion- mode 
FETs* used as pull-up resi- e made as large as pos- 

sible to reduce power dissipation and permit the use of a 
plastic DIP, but were constrained to be small enough to 
guarantee the minimum operating frequency and econom- 
ical die size. Approximately 24,000 FETs are fabricated on 
a die 3.68 mm by 5.46 mm. The cost of this part is com pa r- 
able to a RAM, which would otherwise be required fur 
storing the row dot image, yet It does much more. 

Variable dot resolution capability was added to the DGL 
to accomodate applications requiring a resolution less than 
the maximum 210 dpi, The distance between the active 
taps in the main shift register must be effectively reduced. 
This is accomplished with additional control logic that 
periodically interrupts the simple filling procedure of the 
main shift register to inject a specific number of dummy 
fill bits. For example. In a 132-hammer printer programmed 
for 140 dpi. 7 dummy fill hits would follow every 14 print- 
able dots passed into the main shift register. This padding 
process ensures that the actual printable bits, isolated in 
groups by the dummy fill bits, are directly beneath the taps 
of the main shift register. The dot position encoding system 
divides the print space into fewer but larger intervals so 
that only these actual printable dots are drawn out through 
the taps and passed to the hammer fire electronics. The 
fill bits are abandoned since they just reach the taps at the 
very com plot ion of the printbar pass. In the HP 256X family 
of line printers, standard 10 -pitch characters are printed 
at the delaull 210 dpi resolution, compressed 16.fi 7- pitch 
characters are printed at 200 dpi resolution, ami graphics 
printing is done at both 70 dpi and 140 dpi. The readability 
of optically scanned bar codes is established by the width 
ratio of the narrow and wide bars and spaces, which in 
turn is determined by dot size and dot resolution. For the 
nominal dot size of these printers, special barcode resolu- 
linns of 100 dpi and 110 dpi are used to meet military 
standards. 

Although flic DGL control electronics required to fill the 
smart shift register is relatively elementary, this logic was 
placed in a small CMOS gate array to achieve additional 
ivings and reliability. 

Hammer Driver Circuits 

All HP 25 BX Printers have very similar circuits to drive 
the print hammers. Tin- hammer driver shift register re~ 
ceives serial dot data from the 2772-bit shift register via 
the 132-bit output shift register of the DGL. Once this data 
is loaded, it is clocked into a set of data fetches by the FJRE 
signal from the dol position encoder circuitry (Fig. 1 ). Each 
of these latches drives Ihe base of a Darlington transistor, 
which is connected lo a hammer coil. Whtm a transistor is 
energised* current flows through (he hammer coil and 
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creates a magnetic field thai counteracts the field of the 
hammer's permanent magnet, releasing the hammer lu 
print a dot. The fire pulse generation circuitry also provides 
a signal to clear the shift register hitch nnd turn all the 
drive transistors off- This is because the fire pulse circuit 
monitors the very loosely regulated + 50V supply and 
varies the hammer fire signal duration based on the voltage 
level, [If the 4 50V supply is relatively high, the h.immers 
fire for a shorter time and vice vers r i|. Power Zcner diodes 
are used to drain off the energy stored in the hammer coils 
when the Darlington transistors are turned off. 

Printbar Servo Systems 

The servo system in the HP 2565/6 A Printers controls 
the sinusoidal motion of the printbar and supplies position 
pulses to the hammer drive circuit (Fig< 2)- The velocity 
input for the servo loop is supplied by a sine wave generator 
whose frequency and amplitude are determined by I he con- 
trol processor, The processor programs a counter, which 
addresses a ROM containing a digitized sine wave. The 
ROM output goes to a DAC (digital -to-amdog cou verier) to 
produce an analog sine wave, The amplitude of the sine 
wave is established by adjusting the reference input of the 
DAC by means of a second DAC, which is also controlled 
by the control processor. The sine wave is compared to the 
signal from a magnetic velocity transducer attached to the 
printbar. The resulting error voltage sets the current level 
lot tbe pair of power MOSFKTs that drive the linear motor 
attached to the printbar. The frequency and amplitude of 
the printbar motion can thus be controlled by the control 
processor. A digital signal representing the peak drive level 
is also fed back to the processor so that it can sense the 
resonant frequency of the printbar flexure system (see box, 
page 17). A voltage proportional to the printbar position 
is produced by integrating the velocity signal. As the 
printbar moves, this voltage is compared to a second volt- 
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age, generated by a third DAC controlled by the control 
pTOCefl&o nting the next dot position. When these 

voltages are equal, a FIRE signal is sent to the hammer drive 
circuit and the DGL is flagged to output the hammer print 
data lor the next dot position. 

hi the HP 2563 A, sinusoidal printbar motion comes hy 
virlue of the crankshaft, which is driven by a d< servo 
motor. A s^rvu system maintains a constant motor speed 
of 17.5 revolutions per second, or 28.57 itis per single pass 
of the printbar (Fig .3], Since uppercase characters are seven 
dot rows high, this establishes a 300 line-per-mhuite print 
speed. The drive circuit for the printbar motor is basically 
a variable- voltage power supply. The voltage is determined 
by the control processor through B DAC Since it Can n lei- 
sure I he printbar reciprocation rale by timing direction 
change interrupts from the position encoder, the processor 
controls the average speed of the motor, However, a 
hardware feedback loop is also used to increase ih< 
bandwidth of the motor speed control and control the motor 
speed within a single cycle. The motor current is measured 
using a sense resistor, and a voltage proportional to the 
motor current is added to the reference voltage from the 
DAC. This compensates for the voltage drop in the motor 
resistance. 

A linear capacitive encoder is used in the HP 2563A to 
measure the position of the printbar with respect to the 
print mechanism casting [Fig. 4), The encoder includes 
two printed circuit assemblies, One is attached to the cast- 
ing and holds the analog and digital electronics- The other, 
called the pickup plate, has no active circuitry and is at- 
tached to the printbar. A transmitter pattern, consisting of 
five sets of eight fingers, is etched on the back of the active 
encoder printed circuit assembly. The fingers are spaced 
on 0,032-inch centers so that each set of eight fingers spans 
0.256 inch. Each finger of a set is connected to the corre- 
sponding finger of the other sets. The signals to the trans- 
mitter pattern are generaled by an 1 1-MHz clock, which is 
divided by an eight-bit counter, The fifth arid eighlh bits 
of the counter are used to gate and clock an eight-bit shift 
register. The shift register generates an eight-phase pattern 
of square waves, which are connected to the fingers of the 
transmitter pattern. The printbar pickup plate has four 
etched fingers and is positioned directly over the transmit- 
ter pattern on the encoder board. Since each pickup plate 
finger is 0J28 inch wide and hence spans four fingers of 
the transmitter pattern, each pickup finger capacitiveiy 
stims the output of the four transmitter fingers below it. 
The signals from the pickup fingers are capacitively 
coupled back to the encoder board and are amplified and 
filtered to produce .i sine wave whose phase is linearly 
proportional to the position of the printbar with respect to 
the mechanism casting. One cycle of phase shift [360 de- 
grees) represents 0.258 inch of printbar movement. After 
the signal from the pickup plate has been amplified, it is 
used Ui late J-. the state of the first two bits of the counter 
into a pair of flip-flops. The latched value, representing 
the least-significant bits of the phase of the output signal 
at that instant of time, is simply the position of the printbar 
in 0,001 -inch increments. The flip-flop outputs are Inputs 
to a state machine, which generates a direction signal, a 
change-of-direction strobe, and a strobe that is active every 
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time the printbar moves 0.001 inch in any direction. The 
state machine also adds 0.001 inch of hysteresis so that 
the direction signal does not toggle on phase noise, which 
is inevitably present on the pickup plate signal . The outputs 
from the state machine go to the encoder processor (an 
8049) which has 409fc internal ROM to store both 

program steps and dot resolution tables- The dot resolution 
tables map the 0.001 -inch strobe from the state machine 
into the FIRE pulses required to strobe the hammer drive 
circuit for the various HP 256 3 A print resolutions. The 
encoder processor also monitors the printbar motion and 
adds an offset to the dot tables to compensate for printbar 
travel between the time of hammer activation and the flight 
time to the ribbon and paper. This ensures that the dot 
print positions as the printbar moves from right to left fall 
directly over the print positions as the printbar moves from 
left to right. 

Ribbon and Paper Step Drive 

The HP 2565/6A ribbon drive moves the 14.5-inch-wide 
towel ribbon from a supply reel to a take-up reel and back 
with controlled velocity and tension. Two series-connected 
motors, each driving one reel, are used. A constant voltage 
is applied across the two motors with a current sink taking 
a constant current from the common node. This current 
controls the ribbon tension. Both motors drive in the same 
direction when moving the ribbon, with the majority of 
the torque supplied by the pulling motor. 

The HP 2563A ribbon cartridge uses a continuous Z A- 
inch-wide ribbon pulled horizontally across the printbar. 
A geared shaded- pole induction motor, controlled by an 



SCR, is wound to operate from 30Vac so that it can be run 
from the secondary of the power transformer. 

Permanent- magnet step motors are used by all 25BX 
Printers for paper motion. The control processor controls 
the pha^ n and timing. Each full step from the 

motor advances the paper i inch, which is the do! spacing 
for standard print densities, For high*density printing, the 
motor is haJf -stepped, advancing rich. 
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Printer Command Language Provides 
Feature Set Standard for HP Printers 

by Ernest F, Covelli, Von L, Hansen, and David L, Price 



PRINTER COMMAND LANGUAGE (PCL) is a Stall* 
dard language developed by HP to define printer 
features and user access to those features. In the past, 
printers developed by HP and other manufacturers were 
designed with features !h?it were different from device to 
device. Each new printer contained features that were tail- 
ored to the printer's particular mechanism or to a specific 
application. Application programs written for one pricier 
often hud to be rewritten or modified to work correclly 
with another printer. Each new printer required several 
months or even years of software development to support 
its new features. This proliferation of printers and applica- 
tions created a problem known as the "M by N M problem, 
W 1 1' re M is the number of software applications and N is 
the Dumber ol printers. Every time a new printer was intro- 



duced, all M applir ..M> .-n - required modification to support 
the printer. Likewise, each new software application had 
;oport N different printers, 
PCL was developed to bring all HP printers under a com- 
mon feature ami control structure. The major objectives of 
PCL are to standardize printer features and to standardize 
how features are accessed and implemented. PCL is the 
protocol that addresses the control of printer feaU_ires by 
user or system application programs. This is the highest 
level of communication between the system and printer. 
PCL does not address the lower levels of the system struc- 
ture, such as driver control, network communications, or 
I/O interfaces. 
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PCL Architecture 

It was deter miimci ftfeal nu single set of printer features 
could meet the needs of all printer markets. For example, 
to define the standard feature set as a combination pi il! 
desired features would make the low- cost printer too ex- 
pensive. Likewise, to prohibit advanced features in the PCL 
standard would restrict high-level applications and printer 
markets needing advanced features. The solution was to 
partition the printer market into four major application 
segments: print and space, electronic data processing (EDP) 
and transaction, word processing, and page formatting, PCL 
was then aligned with the four major market segments: 

■ Level I Print and Space 

■ Level II EDP and Transaction 

■ Level III Word Processing 

■ Level IV Page Formatting. 

Each level provides a well-defined set of features that 
address the needs of its respective market. Each PCL level 
is a proper superset of the next lower level, assuring upward 
compatibility. This structure allows applications to be 
Inverted tn printers at oi above the level for wttich the 
application w r as written. Any ap pM cat i on written using the 
Level I (print and space) features will format correctly nn 
any MP printer, A Level IV [page formatter] printer can run 
any PCL application. 

The features in the PCL levels are designed to meet the 
needs of the four major markets and to be device indepen- 
dent for use with many print engine technologies. Also, 
the PCL structure allows for optional features outside the 
level structure. Optional features provide the flexibility to 
offer a printer-dependent feature or to meet a special market 
application. Examples of optional features include bar 
codes, vector graphics, downloadable fonts, and sheet - 
feeder control. Applications using optional features will 
not work correctly on printers that do not support the op- 
tional features, 

All printers using the PCL architecture must implement 
features identically aiid in full compliance with a specific 
PCL level or be clear about any exceptions, and must be 
specific about optional features that are outside the level 
structure. 

Feature Level Overview 

the prinl and space feature set level | Level I) is designed 
to meet the needs of a low-cost single- user workstation 
with entry-level functionality. The basic feature ceqi 
for a print and space printer is the ability to print ASCII 
data at 80 characters per line using the normal pitch font 
and 132 characters per line using the compressed pitch 
font. In addition, all PCL printers implement the HP eight- 
bit character set standard, which supports eleven European 
languages. Printer features are accessed by ASCII control 
codes and escape sequences. The control codes supported 
at this level are: line fecd r form feed, carriage return, space, 
and shift in .uid shift out between the primary and second- 
ary fonts. Additional printing features such as automatic 
underline, automatic perforation skip, and raster graphics 
are controlled by escape sequence commands. 

The Level II feature set is intended for general-purpose 
applications such as EDP and transaction printing. Printers 
at this level can be single-user or multiuser devices with 
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a wide range of performance requirements. EDP printers 
use a variety of forms and paper sizes, so features added 
in this level give the application control of the paper size, 
text length, and margins. Additional control of character 
placement is provided by a cursor move to any character 
row or column position. 

The Level III feature set is tailored to word processing 
applications, where high-quality text formatting capabili- 
ties are required. Today there are many devices that fil tnto 
the word processing level. These include the traditional 
daisy wheel and multipass scanning head printers, and the 
latest laser and ink- jet printers. Word processing requires 
a variety of print pitches—ten or twelve characters per 
inch, compressed, and proportional — in upright, italic, and 
hold type styles. All available fonts may be mixed in any 
Fashion on a page or line, Word processing requires the 
ability to do superscripts, subscripts, and precise character 
positioning for centering and justification of text. 

The page formatting Level IV feature set is tailored to 
office information applications requiring advanced text 
and graphics formatting capabilities. Page formatting fea- 
tures include downloadable fonts, high-quality raster 
graphics t electronic forms, page rotation* a variety of fonl 
sizes, rectangular area fill patterns, and rules, Llei tronn 
forms provide a replacement for preprinted forms, which 
require special operator handling and storage. Page rotation 
provides the ability to print either vertically or horizon- 
tally. This additional flexibility is needed to address the 
many types of office apt)] i cat ions, such as spreadsheets, 
reports listings, and documents, Fonl handling has been 
expanded to include small footnote and large display fonts 
for better document presentation and low-end printing and 
publishing applications. Downloadable fonts give the ap- 
plication control over the fonts in a printer, allowing the 
use of custom and HP-supplied fonts. 

Conclusion 

The PCL is a standard that provides consistency among 
HP printers. The features in the levels address the needs 
of the major market seqments, while allowing optional fea- 
tures for special applications. PCL has been successfully 
implemented on many HP printers ranging from a worksta- 
tion printer like the Thinkjel Printer to system printers like 
the HP256X family ot line printers (see Table I). These PCL 
printers use a wide variety of printing technologies such 
as thermal ink-jet, electrophotography, serial dot matrix, 
and line printer dot matrix. New markets have been opened 
because of PCL's consistent structure and product offerings. 
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PCL will help us continue to meet the present and future 
printing needs of our customers, 

Acknowledgments 

The PCL standard was developed jointly by HP's Boise 
and Vancouver Divisions. We wish to extend our thanks 
to all of the members of the PCL committee, especially 
John Ignoffo. Jim Langley. Carol Peterman. Mike Ard, and 
Mike Sproviero, for making PCL a successful interdi visional 
effort. 



Authors 



June 



4~ Dot Matrix Line Printers— — — 

Bryce E. Jeppsen 

Now R&D manager at HP's 

Boise Division, Bryce 
Jeppsen was born in 
Brigham Cily, Utah and 
earned both a BS degree 
and an MSEE degree from 
Bngham Young University 
m 1 970. He also served m 
the U.S. Army for two years. 
Al HP since 1970, he has 
contributed to the develop men I of a number ol 
products, including the HP 543GA Microwave Fre- 
quency Counter, the HP5345A Electronic Counter, 
and the HP 1059QA Plug- In Adapter He also 
served as project and section manager during the 
development of Ihe HP 256X family ol printers, 
Bryce is a resident ol Meridian, Idaho and works 
,rch vuuth groups He is interested in radio- 
controlled airplanes and boats 




& ZZ Printbar Design 



John S. Craven 




Born in San Francisco, 
California, John Craven at- 
tended ihe University ol 
California at Berkeley, 
earning a BSME degree m 
1971 and an MSME degree 
in 1975 He |omed HP's 
Avondale Division in 1975 
and contributed io the de- 
sign ot the (hernial conduc- 



tivity detector for the HP 5880 A Gas Chromato- 

graph and to the system design ot the HP 5890 A 
Gas Chromatograph More recency, he did The 
printbar design for the HP 256* Printer He <s 
named the inventor on three patents on modulated 
fluid detection of thermal conductivity. John lives 
in Eagle, Idaho, is married, and enjoys outdoor ac- 
tivities, including hiking, all kinds of skiing, and 
bicycling, He says he and his wife are also "siowly 
• ii ii bl iing a house we can't afford." 



TV? 



9^ Low-Cost, High-Reliability Printer ;^^= 

Ben B* Tyson 

Ben Tyson studied product 

^f0^K design at Stanford Univer- 
T l^k sity, earning a BS degree in 

^^ ^^1M i976andanMSdegreein 
19 V* W 1977 He has been al HP 
since 1977 and has 
specialised In impact 
pr rnte r de s i gn He fa 1 1 owe d 
the HP 2563 A Line Printer 
from product design to pro* 
duction engineering. Ben lives m Lagle. Idaho, *s 
marned, and has two daughters, He assists in 
teaching science in local elementary schools and 
enjoys tennis as welt as making and playing musi- 
cal instruments. 



Jeffrey M. Lantz 

Jeff Laruz is a nadve of San 

Francisco, California and a 

ite ot California 
Polyi&chnic Stale Univer- 
sity al San Luis Obispo 
{BSME 1979) At HP's 
Boise Division since 1979. 
he was a production en- 
rft W J ^^ gineer on the HP 2608 A 
, I Printer and HP 7970 Tape 

Drive He also contributed to ihe design ol flu.- pt&t 
en and flexure system for the HP 25&3A Line 
Prrttjei Jett lives in Meridian, Idaho, is married io 
a noiher H P eng meer , and has one ch 1 1 d Out side ol 
worn k he enjoty i tniry skiing and bicycling 




13 =z Mechanical Design : 




Daniel D. Wheeler 

Born in Lexing le- 
pra Ska, Dan Wheeler re- 
ceived a BSME degree 
from the University ol 
Nebraska m 1981 He 
came to HP the same year 
and has coniriboted to the 
development of tne HP 
2565 A and HP 2566A Print- 
ers Dan lives in Boise, 
Idaho, is mamed, and is interested in flying. He is 
restoring a 1 946 J -3 Piper Cub and also enjoys ski- 
ing, basketball, and racquatbali 



Peter Gy sling 

Pete Gyslmg was bon i rfi 
Minneapolis. Minnesota 
and is an alumnus of the 
University of Minnesota 
I BSME 1970) Atlur coming 
to HP in the same year, he 
contributed to the develop- 
ment of Hie HP 2608S, HP 
2565A, and HP 2566A 
Printers and is currently in- 
volved in production engineering work tor the 
£565 A and ihe 2566 A His work has resulted ir i two 
patent applications, one on a pass^t papa? 
stacker and ihe other on a tractor positioning sys- 
tem Pete lives in Boise, Idaho and is interested in 
motorcycling, camping, remodeling old houses, 
and ice hockey. He also enjoys driving his four- 
wheel-drive pickup truck. 




George V. Mcllvaine 




Born m Boston, Mas 
sachusetts, George 
Mcllvaine received a 
bachelor's degree trom Ihe 
US Military Academy in 
1972 He served as a cap- 
ain in the U S Army and 
continued his education at 
Stanford University trom 
which he received an 



JUNE 1985 HEWLETT PACKARD JOURNAL 25 



)Copr. 1949-1998 Hewlett-Packard Co. 



MSME degree in 1 979. He has also completed an 

MBA degree at Boise State University (1334) After 
joining HP in 1980 he worked as a production en- 
gineer on Ihe HP 7976A Tape Drive and on the HP 
260BA Line Printer Later he was an R&D project 
manager for the HP 2565A and HP 2566A Primers 
and ts now an engineering services manager. His 
work has resulted in a paient application for a 
material handling device He Mves m Boise, Idaho 
with his wife and three children He and his wife are 
sponsonng their second foster child with the Chris- 
tian Children's Fund and his leisure activities in- 
clude racquetball, aerobic exercise, and skiing. 



Stephen L Testardi 

Steve Testardi was born in 

^JMfe^ Abbington, Pennsylvania 

fli^^^^k ano stua.ed at tne V-rgir.:a 

W ^J Polytechnic Institute, trom 

\^^ ^f *!J which he received a BSME 

^^ fc « Degree in 1980. After com- 

Jj/fibij ,n 9 t0 HP ' S ^ 0LSe Division 

^E^^P^ The same year, ne worked 

L^m on -he resonant print bar 

vRL system and lower casting 

design of the HP 2566A Lne Printer. He is also 
named comventor on a patent application on the 
printbar system He is presently doing work on im- 
pact hammers , Steve -s a resident ol Boise, Idaho 
and regu-ariy gives demonstrations on science and 
engineering at a local elemeniary school He hfces 
backpacking, racquetball. and photography and 
s learning lo play the guitar 



is: 



I Electronics and Firmware! 




rv > 



Donald K. Wad ley 

I At HP ENhca 1976. Don 
Wadley is currently a proj- 
ect manager for a luture 
product. He contributed to 
1 the design of Ihe HP^IB 
controller for the HP 7970 
J Tape Drive, was a pro?eci 
Y leader for the controller on 
the HP 7976 A Tape Dt « 
^ BBC* and worked on the HP 

2 563 A Line Printer Don was born :n Milwaukee. 
Wisconsin attended The University Of Wisconsin at 
Milwaukee, and earned BSEE and MSE E degrees 
in 1975 and 1 976 He is interested in manipulator 
research and did some work on manipulators for 
the Alvm submarine at the Woods Hole Oceano- 
graphy Institution. 



Philip Gordon 




Phil Gordon came to HPs 
Data Systems Division in 
1972 and has contributed 
to the development of the 
HP 1000 Miseries O | 
ers and to the design of the 
processor for the HP 1 D00 
E-Senes and F-Senes After 
a transfer to the Boise Divi- 
sion, he was a desrgn en- 




gineer and project manager for the HP 2630A 
Printer. Recently, he contributed to the logic design 
of the controllers 'Or Ihe HP 25BX Printers and de- 
signed the circuits and artwork for the VLSI compo- 
nent He is named inventor on two patents related 
to processor and shift register design Phil was 
born in Los Angeles, California and 15 currently a 
residenl of Boise. Idaho. He receded a BSEE de- 
gree irom Ihe University of California at Berkeley 
in 1 972 and an MSE E degree from Stanford Univer- 
sity in T980 



Phillip R. Luque 

■■ ■ At HP since 1973. Phil 

Luque first worked in the 
Santa Rosa Division on the 
receiver portion ot ihe HP 

P M 8754 A Network Analyser. 
™ 'erairansfertotheBoise 

• ned to 
d J the design of the analog 
^m electronics of Ihe HP 2631 

^F Printer and lo the destgn of 

t h e po we r Supply fof t tie H P 2 563 A L i n e Pri n t e • h u 
was also a production engineer for the 2563A He 
is named comventor on a patent application on Ihe 
encoder for the 2563A Phil is a native of Boise, 
Idaho and an alumnus of 9 rig ham Young University 
(BSEE 1 972 and MEEE 1973} He now lives in Boise, 
is mamed and has five children. He teaches sci- 
ence at a local elementary school and is active in 
church work He enjoys folk dancing and astronomy 



33 — Printer Command Language! 

David L. Price 

A development engineer at 
HP's Boise Division, Dave 
Price has contributed to 
firmware design for the HP 
26085 and HP 2563A Print- 
ers. He is a lifelong resident 
of Idaho who was born in 
jfflBK /m \ Poc ale Ho and educated at 
1 j^^flHW L ' he University ol Idaho 

I^BKJ" (BSEE i960). He now lives 
in Boise, is married, and has two children. His lei- 
sure interests include softball, backpacking, and 
skiing 



Ernest F. Covelli 

At HP's Boise Division 
5 nee 1980. Ernie Co veil i 
was born in Azusa, Califor- 
nia and attended California 
State Polytechnic Univer- 
sity al Pomona, from which 
he earned a BSCS degree 
ih 1 &80. Ai HP. he has con- 
tributed to the enhance- 
ment, testing, and support 
of Ihe HP 2660 A Pnnter and the HP 2686 A Page 
Printer He has also worked on formatter testing 
and specifications for the HP LaserJet Primer A 
resident of Boise, Idaho, he I rkes hiking, camping, 
all types of skiing, swimming, golf, and gardening 





Von L. Hansen 

I At HP's Boise Division 
I since 1976. Von Hansen s 
I the project manager for 

I electronic data processing 
and office printer control- 
lers. He was responsible for 
the controllers for the HP 
LaserJet Prmterand for The 
HP 2566A Printer Von was 
I born In, Logan, Utah and 
attendee Utah State University (BSEE 1976) and 
Stanford University (MSEE 19B0) He lives in Boise, 
Idaho, s married , and has tour children, including 
a set ot twins He ts a scoutmaster in ihe Boy Scouts 
ol America and is interested in tly-lishing, back- 
pack-^g. skiing, and racquetball. 




27 ^z Native Language Support : 




Harry E. Ketlogg 

Harry Kellogg came to HP 
in 1976 after completing 
undergraduate degrees in 
1 Greek at Stanford Univer- 
sity (1969) and in 
mathematics at ihe Univer- 
sity of California at Berkeley 
^^^^^|^^ ( 1 971 } as well as an MS m 
^L 1^ mathematics ai Ihe State 

rl^Hk ^1 I University of Mew York al 
Buffalo (1976). At HP he worked on various internal 
projecls and alter a transfer to Germany contrib- 
uted to financial accounting soil ware for the HP 
3000. Now a member ot the Computer Systems Di- 
vision, he is Nalive Language Support project man- 
agar lor ihe HP 3000 Harry was born in Chicago, 
Illinois and now I eves tn Monta Vista. California He 
is married and has two children. He is a member 
of the ACM and a coach tor a youth soccer league 
His other interests are singing, swimming, and 
reading. 

Jonathan E. Bale 

^^^^ A naiive ot Cleveland. Ohio, 

^M B^ Jon Bale was educated al 

^J^^^^A the University ot Colorado 

(BA Mathematics* 1968) 
^^^ Y^ and Princeton University 
(MSEE. 1969) He joined 
HP rn 1969 and has since 
contributed to a number of 
software design and de- 
velopment projects for Ihe 
HP 3000. He was a member of the original design 
team tor the Image data base manager and has 
worked m the Netherlands as a customer support 
engmee f ar ,d in England as a systems engineer, 
More recently he worked on standards tor Euro- 
pean language support and was project manager 
for HP 3000 Naiive Language Suppori He now 
coordinates NLS development activities for all HP 
compute' pioducls Jon lives in San Jose. Califor- 
nia with his wife and two children and enjoys bicy- 
cling, photography, and travel. He also claims that 
one of his hobbies is 'reading HP Journal biog- 
raphies 




26 HEWLETT-PACKARD JOURNAL JUNE 1985 



)Copr. 1949-1998 Hewlett-Packard Co. 



Native Language Support for Computer 
Systems 

NLS for the HP 3000 and other HP computers provides 
hardware and operating system facilities that make 
application programs easy to translate into other 
languages. 

by Jonathan E. Bale and Harry E. Kellogg 



SUPPOSE that someone within your company, but 
in another country where another language is spo- 
ken H has written a very good computer program, You 
would like to provide this program to users in your own 
court try, but you know that they will not understand many 
of the conventions or the language of the country in which 
it was written. The program needs to be localized for your 
country before it can be useful there. What kinds of things 
do you need to be concerned about? 

First of all, of course, there is the language. All text that 
is part of the program, such as menus, error messages, a 
help facility, and so on, needs to be translated from the 
original into your native language. But that is not all There 
are other aspects of the dialogue the program carries on 
with its user that must be considered, such as the format 
in which dates or numbers are entered or displayed. Also, 
internal processing of data, such as sorting and upshifting 
[capitalizing), may need to be localized to meet local con- 
ventions or requirements. 

How easy is it to localize all of these feal nrest It depends 
on how the original program was written, ff no thought 
was given to the possibility that the program might be 
localized for another country, then it is likely that error 
messages, the format of dates, and the rules tor upshifting. 
for example, are part of the source code of the program. 
The program can be localized only by changing the source, 
that is, by rewriting parts of it. This makes the localized 
version a new program. Not only is it a great deal of work 
In find fcfae appropriate places, decide on and make the 
recompile, link, and rates! the Q&W program, but 
this also raises the possibility of introdui Jul; new bugs into 
the program, and it greatly complicates its support, II a 
user reports a hug, does it get referred to the group that 
wrote the original version of the program, or to the group 
that localized the version being used? 

If some thought was given to the possibility of the pro- 
gram being localized, then it may he considerably easier. 
However the original effort to make the program easy to 
localize may have represented a substantial fraction of the 
total design and programming time. For example, in the 
September 1984 Hewlett-Packard (ournal. Wilson and 
Shaw 1 describe what the designers of HP office software 
have done to make it possible for other countries to localize 
tliM software without having to modify any source? code 
So that each application doesn't have to develop its own 



way of flexibly handling language-dependent features, the 
concept of native language support (NLS) has been de- 
veloped by a number of cooperating Hewlett-Packard divi- 
sions. NLS is an internal set of facilities, both hardware 
software, that let application programs executing on a 
computer system have a natural local look to a user in any 
country, including local language text and manipulation 
of data according to local usage, NLS is to be distinguished 
from localization, which is an external effort to make an 
application written in one country perform appropriately 
in another, Localization is much easier Li .implication pro- 
grams have been written to make use of native language 
support facilities. This relationship is summarized in Fig. 1 , 

The native language support that has been implemented 
recently on several HP computer systems [HP 3000, HP 
lOuu. HP 150) makes software applications easier to 
localize by providing language- or country-dependent in- 
formation, as well as the tools to use this information, as 
part of the computer system itself. NLS is typically part of 
the operating system, but may also be embedded within 
processor hardware or peripherals where appropriate, 

The application programmer uses these facilities in pro- 
gramming the application, at little extra cost compared 
with conventional programming, They serve to separate 
from tin! program code those aspects of the application that 
vary from one language to another or from one country to 
another. Country Software Centers (or other local groups] 
then localize the application for their own countries and/or 
languages. At this point localization usually requires only 
translation of text (prompts, commands, error messages, 
etc.) into the local langmit^. 

The rest of this article describes the components of native 
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Fig. 1 . The boxes show the relationship between native lan- 
guage support, which is provided by the firmware or operating 
system and used by the applications programmer, and locali- 
zation, which is done by the software localizer. Localization 
is made much easier, andean often, be limited to translation 
of text, if native language support features have been used. 
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Fig. 2. The Romans character set 
lable. This is the most commonly 
used of the extended 8-bit charac- 
ter sets that provide the additional 
characters necessary to support 
languages other than American 
English, 



language support and how application programs can use 
them . 

Character Sets 

Support of native languages on HP computers is depen- 
dent on the use of so-called extended [in most cases, 8-bit) 
character sets. The original character set supported by Hew- 
lett-Packard hardware and software was USASCII, a 128- 
member set of characters designed to support American 
English text. Each character within a US A SCI I -encoded 
stream of data occupies one byte (eight binary digits or 
bits), although the code assignments for these characters 
are densely packed into the range of to 127, which means 
that the value of the high -order (most -significant) binary 
digit is always zero. For this reason, USASC11 is referred 
to as a 7-bit code. 

Because an 8-bit byte fundamentally has the ability to 
contain 256 unique values, it is possible to represent 
character sets larger than US ASCI I within a one-byte encod- 
ing scheme. This is the approach that has now been taken 
within HP for the encoding of characters required by lan- 
guages other than American English , These new character 
sets have the following features: 

■ Bach is a superset of US ASCII. Therefore, all US ASCII 
characters are available, and have their normal code val- 
ues. 

■ All new characters (with code values greater than 127) 
are available to serve the needs of non-U.S. languages. 



■ It is oft nn possible to support multiple languages unam- 
biguously with a single set. This can be of great advantage 
when data is exchanged between countries. 
For native language support, each language to be sup- 
ported is associated with a known 8-bit character set. There 
are Currently I wo such character sets that are widely sup- 
ported by native language support hardware and software: 
Roman8 for Western-European-derived languages (see Fig, 
2), and Kana8 for the support of Katakana. a Japanese syl- 
labary that allows Japanese words to be written phoneti- 
cally rather than with pictngraphie characters. 

Peripherals and Applications 

Obviously, the support of native languages depends not 
only on the software's ability to recognize and manipulate 
native language characters, but also on the ability to input 
and output these characters. Most HP terminals, plotters, 
and printers are capable of handling one or more of the 
currently defined 8-bit character sets. 

The use of 8-bit character sets for NLS implies that in 
character data, all bits of every byte have significance. Ap- 
plication software must take care not to tamper with the 
eighth (high-order) bit. For example, it was previously com- 
mon in data torn muni cations software to use the eighth 
bit as a parity bit to check for correct transmission of data, 
or in word processing software to use the eighth bit to 
indicate whether a character should be underlined when 
it is printed. Alternative methods must be found to ac- 
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compUsh purposes of this nature. Also, no differentiation 
should be made between characters having the eighth bit 
on and those having it off, because all are characters of 
equal status in an extended character set, 

Languages 

In the recent native language support (NLS) project for 
the HP 3000 Computer, we defined 14 supported languages 
as a part of the MPE operating system (see Fig. 3). Each 
language is identified in the system by a unique language 
name and language number. 

The definition of each of these languages includes a 
number of characteristics of thai language. Some of these 
are really language related in the traditional sense, such as 
day and month names and lexical order (collating se- 
quence). Other characteristics associated with a supported 
native language are really country or local custom depen- 
dent, such as currency symbols and date formats. Another 
group of characteristics is data processing oriented — for 
example, the conversion algorithm between the HP 3000 *s 
character representation [a superset of ASCII) and the 
EBCDIC used by some other computers. 

Within NLS, ail of these characteristics — language re- 
lated, custom dependent , and data processing oriented — 
are considered to be language dependent. All information 
and data manipulation available from NLS are based on 
the application's choice of a language. Thus, for example. 
NLS maintains not only an English upshifting algorithm, 
but also an English time-of-day format. In the latter case 
"English" may be considered to mean "used In England" 
rather than "of the English language." 

hi some cases, more than one HP supported language 
has been introduced for a single natural language. This is 
done in cases in which there are known differences in one 
or more of the fundamental language characteristics, For 
example, the upshifting of accented vowels is handled dif- 
ferently in French Canada and in Prance, The French drop 
the accent in the uppercase version; the French Canadians 
do not, We support this difference by providing separate 
languages. 

Conversely, each of the supported languages may be con- 
sidered a language family, potentially usable in multiple 
countries, Thus, the language German is usable in Get- 
many , Austria, Switzerland, or anywhere else it is desired, 

A list of the characteristics of a supported language is 
shown in Fig. 4. An interesting example, the collating se- 
quence or lexical ordering of a language, is discussed In 
the box on page 30, These characteristics were defined by 
the HP 3000 NLS project with the help of HP Software 
Centers in the various countries. Nhim >i tip in can be 
modified by the user. 

Intrinsics 

NLS provides system library routines, or intrinsics as 
I hey are called on the HP 3000* to access or to use the 
language-dependent information. Each intrinsic accepts a 
language number parameter in addition to whatever other 
parameters it needs This language on m her determines 
which language-dependent information the intrinsic ac- 
cesses and how it works on any data provided. 

An application program can use these intrinsics to re- 
place traditional programming techniques that may he 



biased towards American English usage* For example, to 
upshift a string of characters, a program has traditionally 
subtracted 32 from the code value of each character in the 
range a to z. This is because 32 is exactly the difference in 
the codes of the corresponding uppercase and lowercase 
characters within the ASCII code table. For example, the 
internal code for the character n is 110; for the character 
\ ! it is 78. Such a technique no longer works with the 
Btcter e of the Romans character set since for historical 
reasons e could be placed neither within the range a to z, 
nor at a distance of exactly 32 either from E (for French) 
or from E [for Canadian French and most other languages 
supported by Ruman8). The application instead calls the 
NLSCANMOVE intrinsic, requesting upshifting and passing 
it a language number. NLSCANMOVE passes back a string 
that has been upshifted correctly for the requested lan- 
guage. 

Similarly, instead of calling the old intrinsic FMTDATE to 
format a dateline in the traditional HP 3000 format, an 
application calls NLFMTDATE. which is called in the same 
way except that it takes the extra parameter langnum. 
NLFMTDATE formats the dateline in a language-dependent 
fashion. This call might produce "Sun, Oct 7 r 1984, 2:42 
PM" if langnum were 1 (American), but "So 7 Okt 1984. 
14.42 " if langnum were 13 (Swedish). 

In addition to the 14 real languages supported by 'he 
first release of NLS for the HP 3000, a dummy language 
called Native 3000 [language number 0] has also been 
created for backward compatibility. The characteristics of 
Native 3000 may be thought of as "the way it used to work/' 
For example, a request to NLSCANMOVE to upshift for langnum 
will affect only the characters a through z and in effect 
subtract 32 from each occurrence. A call to NLFMTDATE with 
langnum will have the same result as a call to the old 
FMTDATE intrinsic. 

Application Message Catalogs 

A localizable program has as one of its characteristics 
the attribute that no texl [prompts, commands, messages, 
menus) is stored in the source code. This allows the text 
material to be translated easily (as part of the localizatlo i 
step) without modifying the source code, For the NLS proj- 
ect we created a new application message facility with the 
following features, which were felt to be essenl Sal for native 
language support: 
■ Accessible via intrinsics callable from all of the major 

programming languages, so that all types of programs 

American 

Canadian French 

Danish 

Dutch 

English 

Finnish 

French 

German 

Italian 

Norwegian 

Portuguese 

Spanish 

Swedish 

Katakana 

Fig. 3. The languages supported by the first release of NLS 
for the HP 3000. 
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Native Language Collating Sequences for Europe 



One of the attributes of languages thai varies from one to another 
is the collating sequence or lexical ordering of characters and 
words that may appear in that language. Alphabetical order may 
be considered the starting point for this, but it must be extended 

to take into account numbers, punctuation marks, foreign charac- 
ters, and so on In that characteristic of a supported native lan- 
guage known as its collating sequence, native language support 
for the HP 3000 rs able to provide the accepted dictionary order- 
ing for all of the native languages supported 

Thts is a considerable improvement over traditional computer 
collating, which orders characters in the order of their internal 
representation, This happens (not quite by chance) to order the 
English letters A through 2 in the correct oraer. but it does not 
provide collating of lowercase a between A and B, nor does it 
handle such European requirements as the German B, which is 
ordered in German dictionaries as though it were ss, or Spanish 
words beginning with ch, which are found after all other words 
beginning with c, since ch is treated jn Spanish as a single letter 
distinct from c. Nor does it satisfy the requirements of the French 
that the accents on vowels be ignored in collating words, unless 
the words are identical except for accent, in which case a rigid 
order of accent marks is prescribed 

To handfe these and other requirements of supported ian- 
guages, the definition of a collating sequence and the collating 
algorithm provide the following options: 
1- Reordering the collating of characters. For example, a and a 

can be collated between A and B even though their internal 

representations do not lie between A and B. 

2. Two-for-one substitutions. A single character can be collated 
as if it were two characters, For example , the R from German 
is collated for ail Romans supported languages as though it 
were ss 

3. One-for-two substitutions, A pair of characters can be collated 
as if they were a single character For example, In Spanish 
the letter pair ch js collated as if it were a single letter, distinct 
from either c or h, and collating between c and d 

4. Character priority. This allows differences between two 
characters to be ignored (the two are considered equal), un- 
less all subsequent characters in the strings being compared 
are also equal (or treated as equal), in which case priorities 
assigned to the otherwise equal characters are compared to 
break the tie. The typical use of this option is for case (upper 
versus lower) and accent (vowels with and without) differ- 
ences. For example, for all of the languages supported by 
the Romans character set the e vowels (upper or lower case, 
with or without accent) are treated as equal except for priority; 
their priority order is E e E e E e E e E e 

5. "Don't care" characters it may be appropriate to ignore cer- 
tain characters \n comparing strings. The result will be the 
same as if such characters were simply removed from all 
strings containing them. This option is not employed in any 
of the currently supported languages on the HP 3000, How- 
ever, it will be necessary for the definition of some languages 
for which future support is planned. 



One of the principles followed in the definition of native lan- 
guage collating sequences is that, for a given character set, 

every character in that character set may appear in data for any 
language supported by the character set. For example, the 
character a might appear in an American data base, even though, 
strictly speaking, it is not an English letter Thts makes practical 
sense, because terminals and printers are implemented to sup- 
port a character set, not a language Therefore, it is possible for 
any of the characters to get into data tt also makes data process- 
ing sense, because even if a certain character doesn't exist in 
a certain language, it may still occur in names, foreign addresses, 
and so on, IS is very useful to be able to address a letter to 
Germany correctly, even when it originates in Italy. 

Another principle followed is thai a character that does not 
usualiy appear m a language should be collated where users of 
that language might be expected to look for it. For example, the- 
se character, which actually collates after z in Danish and Norwe- 
gian, is collated as if it were ae in all other languages, using the 
two-for-one substitution option. 

Application of these principles tc the definition of the collating 
sequence for the Spanish language results in a sample list of 
words being sorted as follows: 

covert 

charro 

forest 

Forster 

Forster 

fortify 

nascent 

naft 

nasty 
In any other Roman8 supported fanguage but Spanish, the 
first two words would be exchanged, but otherwise the order 
would be the same. 

These collating sequence principles are implemented ffi an 
algorithm in the routine nlcGllate. which may be called from 
any program A program that wants to compare two character 
strings to order them alphabetically in a list such as that above 
would traditionally have used a programming language construct 
like: 

IF stringt <string2 H (string length) THEN ... 

which is typically compiled to execute a hardware "compare 
byres" instruction. Such an instruction orders characters only 
according to their internal representation. This can now be re- 
placed by the following call: 

NLCDLLATE fstnngT. stnng2. stringlength, langnum H result} 
IF result < THEN ... 

which performs correctly for whatever the current language 
number happens to be Considerable effort was invested in op- 
timizing the algorithm that implements this collating sequence, 
so that users of native language collating sequences pay only 

a minimal performance penalty. 



can use it. 

Efficient in its storage of text to minimize the disc space 

used by any particular message catalog. This makes it 

practical for an application to have text available and 

on-line in several languages at one time. 

Fast in accessing and displaying text, so that its use is 

not discouraged by poor response time. This is achieved 



by a two- layered directory of messages with caching of 
the most recently used portions, so that access of any 
message requires at most two disc reads, and usually 
only one. 

Flexible in meeting the requirements of different lan- 
guages for storing and displaying text, so that realistic 
translations are possible for all languages. This is 



30 HEWLETT-PACKARD JOURNAL JUNE 1935 



)Copr. 1949-1998 Hewlett-Packard Co. 



Language name, number 

Character set 

Charactef definitions (uppercase, lowercase, numeric, etc) 

How each character is upsbitieo 

How each character is downshifted 

EBCDIC conversion tables (to and from) 

Collating sequence table (correct sorting, order) 

Decimal delimiter, thousands separator (for numeric formatting) 

Currency sign, abbreviation, and position (for monetary formatting) 

Month names and abbreviations 

Weekday names and abbreviations 

External date format 

External time-of-day format 

External custom (short) date format 

Words for yes" and no 

Additional country or language specific information as required 

Fig. 4. Characteristics associated with a supported native 
language 

achieved with variable-length message records and with 
numerical parameters that allow the variable portions 
of a message (inserted at execution time) to appear in 
any order in the message, 
■ Easily maintained message sources. A merging of a mas- 
ter and a maintenance message file (such as hay long 
been available for compilers of source code) is built into 
the utility program that builds message catalogs. This 
way, when the original language messages change, it is 
easy for the localizer to isolate and translate only the 
changed portions and to recreate a new translated catalog 
quickly. 

An application would use this message catalog facility 
to replace traditional messages hard-coded within the pro- 
gram as follows. Suppose that a Pascal program would 
normally have contained the line: 

WRITELN ( The data set ', dataset_name, ' does not belong', 
to the data base ', database_jiame. 



and the data set name will appear later. This order allows 
a more natural expression of the message in German, 

Subsystems 

In addition to these modifications to the operating sys- 
tem. NLS for the HP 3000 also modified the most commonly 
used subsystems: the data base manager (Image) and its in- 
quiry processor f Query), the screen handler (VPlus), the 
indexed sequential file manager (KSAM), the file copier 
(FCopy), the sort package (Sort-Merge), and one of the com- 
pilers for the programming language COBOL. 

In Image, certain information inside data bases is linked 
in sorted order based on the value of a field in the data. 
This sorted order may now be that of a native language. 
Image accomplishes this by calling the NLCOLLATE intrinsic 
instead of doing a byte comparison on the fields to be 
compared. In the same way. the Sort and Merge programs, 
and the sorting intrinsics that they and other programs use, 
now call NLCOLLATE to compare character keys of records 
being sorted, 

The screen handler VPlus does built-in edits of user 
input. When asked to check a field for valid numeric input, 
it can now vary its results depending on a language, The 
input "1.234,56" is, for example, perfectly valid if the lan- 
guage is Dutch, but not if it is American, VPlus determines 
this based on the valid decimal indicator and thousands 
separator for the language. 

The file copier FCopy can be requested to translate 
characters from ASCII to EBCDIC (or vice versa) while it 
is copying a file. This is also language sensitive now, since 
FCopy calls the new NLTRANSLATE intrinsic to be sure that 
the translation is into the correct version of KHCDIC, which 
varies from country to country, Previously, FCopy used a 
built-in table based on the American version of EBCDIC 



This statement has the effect of writing n tine containing 
some constant English text with two variable strings 
[dataset_name and database_name) included. To make this 
function language independent, a message catalog is pre- 
pared in which, let us say T in message set 7 is found the 
following message number 23; 

23 The data set fl does not belong to the data base (2. 

In the program the WRITELN statement shown above is 
simply replaced by: 

CATREAD ( cat_index, 7. 23, nl.„error t , f datase^name, 
database_name ); 

where cat^index is a pointer, which was returned at the 
beginning of the program when the message catalog was 
opened, and nL_error is a parameter, to which error values 
may be returned if the call is unsuccessful The German 
version of the same catalog might contain message, number 
23 translated as follows: 



Data Base 



IMAGE Data Base(s) 

with Appropriate 
Language Attribute(s) 



Indexed Sequential 



KSAM File(s) 

with Appropriate 

Language Attributes) 



Sort-Merge 

Intrinsics 



Character Manipulation 



NL intrinsics 

(e.g., NLCOLLATE 
WLSCANMOVi) 



Application 
Program 



A Program 
Written 

for Use in 
Multiple 

Countries. 

Determine 

LAMGNUM(S) 

el Run Time 



VRus Forms Filets) wtlh 

Appropriate Language 

or "International" 



Prompts. Messages 



In Application Message 

Calalog(s) Chosen 

by langnum 



User Commands 



Command Filets) or 
Message Catalog(s) 
Chosen by langnum 



nl intrinsics 

(e.g., NL5MTPAT1} 



23 Die Datenbank !2 enthalt den Datensatz !1 nicht 

Sine*? tlits order of the symbols !l and !2 has been re- 
versed, the data base name will appsar first in the message. 



Fig. 5. The multilingual application program, using the 
facilities provided by native language support, can be used 
on the same computer at the same time by users with different 
native languages. 
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only. 

Language-dependent processing in all of these subsys- 
tems, or in any application, can be explicitly requested via 
new commands or keywords. But it can also be triggered 
automatically via one of several types of default languages 
available at any time from the operating system. For exam- 
pie, Query reporting from an Image data base is sensitive 
to the user interface language of the Query user. But Image 
sorted chains depend on the data manipulation language 
associated with the Image data base. Of course, these vari- 
ous default languages will often be all the same. But other 
examples already exist in the current HP product Hue in 
which they differ. In HPWord, for example, the distinction 
is maintained between the interface language of the user 
(used for error messages and prompts) and the data lan- 
guage of the document (used, for example, for automatic 
hyphenation). 

The Multilingual Application 

Fig. 5 illustrates a program that has been designed and 
implemented to use the facilities provided by native lan- 
guage support. Such a program can be called a multilingual 
program hecause it can he used on the same computer at 
the same time by users with different native languages. 
Such an application selects its language! s) at run time based 
on information about the system, the user, the application, 
or the data to be processed. For example, it could have 
multiple copies available (one per language) of a message 
catalog and a screen forms file, Systematic choices of names 
lor the different local versions make it possible for the 
application to open the correct files based on the language 
of the user. 

The application also opens any needed data bases or data 
files, which may or may not depend on language choice. 
Text to be displayed is fetched from the message catalog 
or screen forms file. The appropriate language numbers are 
passed to the various native language intrinsic^ to perform 
functions that are language dependent. These include edit- 
ing or formatting of data exchanged with the user, such as 
dales, limes, and numbers. They also include internal ma- 
nipulations such as upshift ing, scanning, character com- 
parisons, and sorting. The same program code now exhibits 
multiple personalities depending on the user and the envi- 



ronment. 

Of course, not all functions that vary from one language 
In smother or from one country to another are provided by 
HP native language support. For example, tax calculation 
rules are usually country specific (or even more local), and 
rules for word hyphenation are language specific, Func- 
tions such as these are considered to be in the domain of 
the application, and are beyond the scope of NLS {so far). 
Nevertheless, applications that perform such functions 
should implement them in such a way that they are easily 
Localized. 2 

Other Systems 

Similar development has recently produced native lan- 
guage support for the HP 1000 and the HP 150 Computers. 
Other projects are under way to provide native language 
support in future generations of computer products, to sup- 
port new languages and character sets, and to support ad- 
ditional characteristics of native languages. 
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